mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-10-31 10:18:42 +08:00 
			
		
		
		
	Excel导出导入支持dictType字典类型
This commit is contained in:
		| @@ -29,6 +29,11 @@ public @interface Excel | |||||||
|      */ |      */ | ||||||
|     public String dateFormat() default ""; |     public String dateFormat() default ""; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 如果是字典类型,请设置字典的type值 | ||||||
|  |      */ | ||||||
|  |     public String dictType() default ""; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 读取内容转表达式 (如: 0=男,1=女,2=未知) |      * 读取内容转表达式 (如: 0=男,1=女,2=未知) | ||||||
|      */ |      */ | ||||||
|   | |||||||
| @@ -2,7 +2,6 @@ package com.ruoyi.common.utils; | |||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import com.ruoyi.common.constant.Constants; | import com.ruoyi.common.constant.Constants; | ||||||
| import com.ruoyi.common.core.domain.entity.SysDictData; | import com.ruoyi.common.core.domain.entity.SysDictData; | ||||||
| import com.ruoyi.common.core.redis.RedisCache; | import com.ruoyi.common.core.redis.RedisCache; | ||||||
| @@ -43,6 +42,58 @@ public class DictUtils | |||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 根据字典类型和字典值获取字典标签 | ||||||
|  |      *  | ||||||
|  |      * @param dictType 字典类型 | ||||||
|  |      * @param dictValue 字典值 | ||||||
|  |      * @return 字典标签 | ||||||
|  |      */ | ||||||
|  |     public static String getDictLabel(String dictType, String dictValue) | ||||||
|  |     { | ||||||
|  |         if (StringUtils.isNotEmpty(dictType) && StringUtils.isNotEmpty(dictValue)) | ||||||
|  |         { | ||||||
|  |             List<SysDictData> datas = getDictCache(dictType); | ||||||
|  |             if (StringUtils.isNotEmpty(datas)) | ||||||
|  |             { | ||||||
|  |                 for (SysDictData dict : datas) | ||||||
|  |                 { | ||||||
|  |                     if (dictValue.equals(dict.getDictValue())) | ||||||
|  |                     { | ||||||
|  |                         return dict.getDictLabel(); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return dictValue; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 根据字典类型和字典标签获取字典值 | ||||||
|  |      *  | ||||||
|  |      * @param dictType 字典类型 | ||||||
|  |      * @param dictLabel 字典标签 | ||||||
|  |      * @return 字典值 | ||||||
|  |      */ | ||||||
|  |     public static String getDictValue(String dictType, String dictLabel) | ||||||
|  |     { | ||||||
|  |         if (StringUtils.isNotEmpty(dictType) && StringUtils.isNotEmpty(dictLabel)) | ||||||
|  |         { | ||||||
|  |             List<SysDictData> datas = getDictCache(dictType); | ||||||
|  |             if (StringUtils.isNotEmpty(datas)) | ||||||
|  |             { | ||||||
|  |                 for (SysDictData dict : datas) | ||||||
|  |                 { | ||||||
|  |                     if (dictLabel.equals(dict.getDictLabel())) | ||||||
|  |                     { | ||||||
|  |                         return dict.getDictValue(); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return dictLabel; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 清空字典缓存 |      * 清空字典缓存 | ||||||
|      */ |      */ | ||||||
|   | |||||||
| @@ -50,6 +50,7 @@ import com.ruoyi.common.core.domain.AjaxResult; | |||||||
| import com.ruoyi.common.core.text.Convert; | import com.ruoyi.common.core.text.Convert; | ||||||
| import com.ruoyi.common.exception.CustomException; | import com.ruoyi.common.exception.CustomException; | ||||||
| import com.ruoyi.common.utils.DateUtils; | import com.ruoyi.common.utils.DateUtils; | ||||||
|  | import com.ruoyi.common.utils.DictUtils; | ||||||
| import com.ruoyi.common.utils.StringUtils; | import com.ruoyi.common.utils.StringUtils; | ||||||
| import com.ruoyi.common.utils.reflect.ReflectUtils; | import com.ruoyi.common.utils.reflect.ReflectUtils; | ||||||
|  |  | ||||||
| @@ -270,7 +271,11 @@ public class ExcelUtil<T> | |||||||
|                         } |                         } | ||||||
|                         else if (StringUtils.isNotEmpty(attr.readConverterExp())) |                         else if (StringUtils.isNotEmpty(attr.readConverterExp())) | ||||||
|                         { |                         { | ||||||
|                             val = reverseByExp(String.valueOf(val), attr.readConverterExp()); |                             val = reverseByExp(Convert.toStr(val), attr.readConverterExp()); | ||||||
|  |                         } | ||||||
|  |                         else if (StringUtils.isNotEmpty(attr.dictType())) | ||||||
|  |                         { | ||||||
|  |                             val = reverseDictByExp(attr.dictType(), Convert.toStr(val)); | ||||||
|                         } |                         } | ||||||
|                         ReflectUtils.invokeSetter(entity, propertyName, val); |                         ReflectUtils.invokeSetter(entity, propertyName, val); | ||||||
|                     } |                     } | ||||||
| @@ -529,13 +534,18 @@ public class ExcelUtil<T> | |||||||
|                 Object value = getTargetValue(vo, field, attr); |                 Object value = getTargetValue(vo, field, attr); | ||||||
|                 String dateFormat = attr.dateFormat(); |                 String dateFormat = attr.dateFormat(); | ||||||
|                 String readConverterExp = attr.readConverterExp(); |                 String readConverterExp = attr.readConverterExp(); | ||||||
|  |                 String dictType = attr.dictType(); | ||||||
|                 if (StringUtils.isNotEmpty(dateFormat) && StringUtils.isNotNull(value)) |                 if (StringUtils.isNotEmpty(dateFormat) && StringUtils.isNotNull(value)) | ||||||
|                 { |                 { | ||||||
|                     cell.setCellValue(DateUtils.parseDateToStr(dateFormat, (Date) value)); |                     cell.setCellValue(DateUtils.parseDateToStr(dateFormat, (Date) value)); | ||||||
|                 } |                 } | ||||||
|                 else if (StringUtils.isNotEmpty(readConverterExp) && StringUtils.isNotNull(value)) |                 else if (StringUtils.isNotEmpty(readConverterExp) && StringUtils.isNotNull(value)) | ||||||
|                 { |                 { | ||||||
|                     cell.setCellValue(convertByExp(String.valueOf(value), readConverterExp)); |                     cell.setCellValue(convertByExp(Convert.toStr(value), readConverterExp)); | ||||||
|  |                 } | ||||||
|  |                 else if (StringUtils.isNotEmpty(dictType)) | ||||||
|  |                 { | ||||||
|  |                     cell.setCellValue(convertDictByExp(dictType, Convert.toStr(value))); | ||||||
|                 } |                 } | ||||||
|                 else |                 else | ||||||
|                 { |                 { | ||||||
| @@ -666,6 +676,30 @@ public class ExcelUtil<T> | |||||||
|         return propertyValue; |         return propertyValue; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 解析字典值 | ||||||
|  |      *  | ||||||
|  |      * @param dictType 字典类型 | ||||||
|  |      * @param dictValue 字典值 | ||||||
|  |      * @return 字典标签 | ||||||
|  |      */ | ||||||
|  |     public static String convertDictByExp(String dictType, String dictValue) throws Exception | ||||||
|  |     { | ||||||
|  |         return DictUtils.getDictLabel(dictType, dictValue); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 反向解析值字典值 | ||||||
|  |      *  | ||||||
|  |      * @param dictType 字典类型 | ||||||
|  |      * @param dictValue 字典标签 | ||||||
|  |      * @return 字典值 | ||||||
|  |      */ | ||||||
|  |     public static String reverseDictByExp(String dictType, String dictLabel) throws Exception | ||||||
|  |     { | ||||||
|  |         return DictUtils.getDictValue(dictType, dictLabel); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 编码文件名 |      * 编码文件名 | ||||||
|      */ |      */ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 RuoYi
					RuoYi