mirror of
				https://github.com/yangzongzhuan/RuoYi-Vue.git
				synced 2025-10-22 10:27:41 +00:00 
			
		
		
		
	Excel导入支持@Excels注解
This commit is contained in:
		| @@ -268,22 +268,15 @@ public class ExcelUtil<T> | ||||
|                 } | ||||
|             } | ||||
|             // 有数据时才处理 得到类的所有field. | ||||
|             Field[] allFields = clazz.getDeclaredFields(); | ||||
|             // 定义一个map用于存放列的序号和field. | ||||
|             Map<Integer, Field> fieldsMap = new HashMap<Integer, Field>(); | ||||
|             for (int col = 0; col < allFields.length; col++) | ||||
|             List<Object[]> fields = this.getFields(); | ||||
|             Map<Integer, Object[]> fieldsMap = new HashMap<Integer, Object[]>(); | ||||
|             for (Object[] objects : fields) | ||||
|             { | ||||
|                 Field field = allFields[col]; | ||||
|                 Excel attr = field.getAnnotation(Excel.class); | ||||
|                 if (attr != null && (attr.type() == Type.ALL || attr.type() == type)) | ||||
|                 Excel attr = (Excel) objects[1]; | ||||
|                 Integer column = cellMap.get(attr.name()); | ||||
|                 if (column != null) | ||||
|                 { | ||||
|                     // 设置类的私有字段属性可访问. | ||||
|                     field.setAccessible(true); | ||||
|                     Integer column = cellMap.get(attr.name()); | ||||
|                     if (column != null) | ||||
|                     { | ||||
|                         fieldsMap.put(column, field); | ||||
|                     } | ||||
|                     fieldsMap.put(column, objects); | ||||
|                 } | ||||
|             } | ||||
|             for (int i = titleNum + 1; i <= rows; i++) | ||||
| @@ -296,14 +289,15 @@ public class ExcelUtil<T> | ||||
|                     continue; | ||||
|                 } | ||||
|                 T entity = null; | ||||
|                 for (Map.Entry<Integer, Field> entry : fieldsMap.entrySet()) | ||||
|                 for (Map.Entry<Integer, Object[]> entry : fieldsMap.entrySet()) | ||||
|                 { | ||||
|                     Object val = this.getCellValue(row, entry.getKey()); | ||||
|  | ||||
|                     // 如果不存在实例则新建. | ||||
|                     entity = (entity == null ? clazz.newInstance() : entity); | ||||
|                     // 从map中得到对应列的field. | ||||
|                     Field field = fieldsMap.get(entry.getKey()); | ||||
|                     Field field = (Field) entry.getValue()[0]; | ||||
|                     Excel attr = (Excel) entry.getValue()[1]; | ||||
|                     // 取得类型,并根据对象类型设置值. | ||||
|                     Class<?> fieldType = field.getType(); | ||||
|                     if (String.class == fieldType) | ||||
| @@ -363,7 +357,6 @@ public class ExcelUtil<T> | ||||
|                     } | ||||
|                     if (StringUtils.isNotNull(fieldType)) | ||||
|                     { | ||||
|                         Excel attr = field.getAnnotation(Excel.class); | ||||
|                         String propertyName = field.getName(); | ||||
|                         if (StringUtils.isNotEmpty(attr.targetAttr())) | ||||
|                         { | ||||
| @@ -610,8 +603,6 @@ public class ExcelUtil<T> | ||||
|             { | ||||
|                 Field field = (Field) os[0]; | ||||
|                 Excel excel = (Excel) os[1]; | ||||
|                 // 设置实体类私有属性可访问 | ||||
|                 field.setAccessible(true); | ||||
|                 this.addCell(excel, row, vo, field, column++); | ||||
|             } | ||||
|         } | ||||
| @@ -1164,7 +1155,17 @@ public class ExcelUtil<T> | ||||
|      */ | ||||
|     private void createExcelField() | ||||
|     { | ||||
|         this.fields = new ArrayList<Object[]>(); | ||||
|         this.fields = getFields(); | ||||
|         this.fields = this.fields.stream().sorted(Comparator.comparing(objects -> ((Excel) objects[1]).sort())).collect(Collectors.toList()); | ||||
|         this.maxHeight = getRowHeight(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 获取字段注解信息 | ||||
|      */ | ||||
|     public List<Object[]> getFields() | ||||
|     { | ||||
|         List<Object[]> fields = new ArrayList<Object[]>(); | ||||
|         List<Field> tempFields = new ArrayList<>(); | ||||
|         tempFields.addAll(Arrays.asList(clazz.getSuperclass().getDeclaredFields())); | ||||
|         tempFields.addAll(Arrays.asList(clazz.getDeclaredFields())); | ||||
| @@ -1173,7 +1174,12 @@ public class ExcelUtil<T> | ||||
|             // 单注解 | ||||
|             if (field.isAnnotationPresent(Excel.class)) | ||||
|             { | ||||
|                 putToField(field, field.getAnnotation(Excel.class)); | ||||
|                 Excel attr = field.getAnnotation(Excel.class); | ||||
|                 if (attr != null && (attr.type() == Type.ALL || attr.type() == type)) | ||||
|                 { | ||||
|                     field.setAccessible(true); | ||||
|                     fields.add(new Object[] { field, attr }); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             // 多注解 | ||||
| @@ -1181,14 +1187,17 @@ public class ExcelUtil<T> | ||||
|             { | ||||
|                 Excels attrs = field.getAnnotation(Excels.class); | ||||
|                 Excel[] excels = attrs.value(); | ||||
|                 for (Excel excel : excels) | ||||
|                 for (Excel attr : excels) | ||||
|                 { | ||||
|                     putToField(field, excel); | ||||
|                     if (attr != null && (attr.type() == Type.ALL || attr.type() == type)) | ||||
|                     { | ||||
|                         field.setAccessible(true); | ||||
|                         fields.add(new Object[] { field, attr }); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         this.fields = this.fields.stream().sorted(Comparator.comparing(objects -> ((Excel) objects[1]).sort())).collect(Collectors.toList()); | ||||
|         this.maxHeight = getRowHeight(); | ||||
|         return fields; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -1205,17 +1214,6 @@ public class ExcelUtil<T> | ||||
|         return (short) (maxHeight * 20); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 放到字段集合中 | ||||
|      */ | ||||
|     private void putToField(Field field, Excel attr) | ||||
|     { | ||||
|         if (attr != null && (attr.type() == Type.ALL || attr.type() == type)) | ||||
|         { | ||||
|             this.fields.add(new Object[] { field, attr }); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 创建一个工作簿 | ||||
|      */ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 RuoYi
					RuoYi