|  |  | @ -152,11 +152,11 @@ public class ExcelOperation { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	 * @throws InstantiationException |  |  |  | 	 * @throws InstantiationException | 
			
		
	
		
		
			
				
					
					|  |  |  | 	 * @throws IllegalAccessException |  |  |  | 	 * @throws IllegalAccessException | 
			
		
	
		
		
			
				
					
					|  |  |  | 	 */ |  |  |  | 	 */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 	public static List readExcel4Update(XSSFWorkbook workbook, int excelInitRow, int excelInitCell, Object obj, String... filter) throws InstantiationException, IllegalAccessException { |  |  |  | 	public static List readExcel4Update(XSSFWorkbook workbook, int excelInitRow, int excelInitCell, String fileName, List<String> rowErr, Object obj, String... filter) throws InstantiationException, IllegalAccessException { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		List<String> filters = new ArrayList<String>(); |  |  |  | 		List<String> filters = new ArrayList<String>(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		Class<?> classz = obj.getClass(); |  |  |  | 		Class<?> classz = obj.getClass(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		filters.addAll(Arrays.asList(filter)); |  |  |  | 		filters.addAll(Arrays.asList(filter)); | 
			
		
	
		
		
			
				
					
					|  |  |  | 		List list = null; |  |  |  | 		List list = new ArrayList<Object>();; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 		 //读取工作表
 |  |  |  | 		 //读取工作表
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 		XSSFSheet sheet = workbook.getSheetAt(0);//getSheet("Sheet1");
 |  |  |  | 		XSSFSheet sheet = workbook.getSheetAt(0);//getSheet("Sheet1");
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	    XSSFRow row; |  |  |  | 	    XSSFRow row; | 
			
		
	
	
		
		
			
				
					|  |  | @ -176,7 +176,7 @@ public class ExcelOperation { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	        	//获得当前行
 |  |  |  | 	        	//获得当前行
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	        	row = sheet.getRow(i); |  |  |  | 	        	row = sheet.getRow(i); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	        	cell = row.getCell(excelInitCell); |  |  |  | 	        	cell = row.getCell(excelInitCell); | 
			
		
	
		
		
			
				
					
					|  |  |  | 	        	if ("-".equals(getValue(cell))) { |  |  |  | 	        	if ("-".equals(getValue(cell)) || "".equals(getValue(cell))) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 					continue; |  |  |  | 					continue; | 
			
		
	
		
		
			
				
					
					|  |  |  | 				} |  |  |  | 				} | 
			
		
	
		
		
			
				
					
					|  |  |  | 	        	//实例化
 |  |  |  | 	        	//实例化
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -203,23 +203,43 @@ public class ExcelOperation { | 
			
		
	
		
		
			
				
					
					|  |  |  | 		        			isAddObj = true; |  |  |  | 		        			isAddObj = true; | 
			
		
	
		
		
			
				
					
					|  |  |  | 		        			String type = tmpField.getGenericType().toString(); |  |  |  | 		        			String type = tmpField.getGenericType().toString(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 			        		//int型
 |  |  |  | 			        		//int型
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 					    	if (type.contains("Integer") ||type.contains("int")) { |  |  |  | 		        			try{ | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    		double dnum = Double.valueOf(cellString); |  |  |  | 						    	if (type.contains("Integer") ||type.contains("int")) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    		int inum = (int) dnum; |  |  |  | 						    		double dnum = Double.valueOf(cellString); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    		tmpField.set(newObj, inum); |  |  |  | 						    		int inum = (int) dnum; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 							} |  |  |  | 						    		tmpField.set(newObj, inum); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    	//double型
 |  |  |  | 								} | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    	else if (type.contains("Double") ||type.contains("double")) { |  |  |  | 						    	//double型
 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    		tmpField.set(newObj, Double.valueOf(cellString)); |  |  |  | 						    	else if (type.contains("Double") ||type.contains("double")) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 							} |  |  |  | 						    		tmpField.set(newObj, Double.valueOf(cellString)); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    	//boolean型
 |  |  |  | 								} | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    	else if (type.contains("boolean") ||type.contains("Boolean")) { |  |  |  | 						    	//boolean型
 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    		tmpField.set(newObj, Boolean.valueOf(cellString)); |  |  |  | 						    	else if (type.contains("boolean") ||type.contains("Boolean")) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 							} |  |  |  | 						    		tmpField.set(newObj, Boolean.valueOf(cellString)); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    	else { |  |  |  | 								} | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 					    		tmpField.set(newObj, cellString); |  |  |  | 						    	else { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 							} |  |  |  | 						    		tmpField.set(newObj, cellString); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 								} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        			}catch(Exception e){ | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        				isAddObj = false; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			        			int errRownum = i+1; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			        			String tmpErrString = fileName+" 第"+errRownum+"行信息有误,注意数字属性,该行请重新填写"; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			        			if (!rowErr.contains(tmpErrString)) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			        				rowErr.add(tmpErrString); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 								} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 			        			break; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        			} | 
			
		
	
		
		
			
				
					
					|  |  |  | 		        		} |  |  |  | 		        		} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        		else { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        			// 记录 excel中为空 的数据--且该条记录不记录进数据库
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        			isAddObj = false; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        			int errRownum = i+1; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        			String tmpErrString = fileName+" 第"+errRownum+"行信息不完整,该行请重新填写"; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        			if (!rowErr.contains(tmpErrString)) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        				rowErr.add(tmpErrString); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 							} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 		        			break; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 						} | 
			
		
	
		
		
			
				
					
					|  |  |  | 		        		 |  |  |  | 		        		 | 
			
		
	
		
		
			
				
					
					|  |  |  | 	        		} |  |  |  | 	        		} | 
			
		
	
		
		
			
				
					
					|  |  |  | 				} |  |  |  | 				} | 
			
		
	
	
		
		
			
				
					|  |  | 
 |