单位转换工具类 1. 工具类转换 - 定义装换枚举转换类型 - 创建转换工具类, 1. 通过反射去除字段, 2.对照传入map标记的字段需要转换的类型转换 3. 重新赋值 2. 注解转换
1. 工具类转换
- 定义装换枚举转换类型
public enum UnitConvertType { ACCURACY , TEN_THOUSAND_YUAN , PERCENTAGE , PERMIL ; }
- 创建转换工具类,
1. 通过反射去除字段,
2.对照传入map标记的字段需要转换的类型转换
3. 重新赋值
@Slf4j
public class UnitConvertUtil { public static < T > void unitMapConvert ( List < T > list, Map < String , UnitConvertType > propertyMap) { list. forEach ( item -> { Field [ ] fields = item. getClass ( ) . getDeclaredFields ( ) ; for ( Field field : fields) { if ( propertyMap. containsKey ( field. getName ( ) ) ) { try { field. setAccessible ( true ) ; Object value = field. get ( item) ; UnitConvertType unitConvertType = propertyMap. get ( field. getName ( ) ) ; if ( value != null ) { BigDecimal bigDecimal; if ( unitConvertType == UnitConvertType . PERCENTAGE ) { bigDecimal = ( ( BigDecimal ) value) . multiply ( BigDecimal . valueOf ( 100 ) ) ; field. set ( item, bigDecimal) ; } else if ( unitConvertType == UnitConvertType . PERMIL ) { bigDecimal = ( ( BigDecimal ) value) . multiply ( BigDecimal . valueOf ( 1000 ) ) ; field. set ( item, bigDecimal) ; } else if ( unitConvertType == UnitConvertType . TEN_THOUSAND_YUAN ) { bigDecimal = ( ( BigDecimal ) value) . divide ( BigDecimal . valueOf ( 10000 ) ) . setScale ( 2 , RoundingMode . HALF_UP ) ; field. set ( item, bigDecimal) ; } else if ( unitConvertType == UnitConvertType . ACCURACY ) { bigDecimal = ( ( BigDecimal ) value) . setScale ( 2 , RoundingMode . HALF_UP ) ; field. set ( item, bigDecimal) ; } else { log. error ( "未知的单位转换类型" ) ; } } } catch ( Exception e) { log. error ( "属性转换失败" , e) ; } } } } ) ; } public static void main ( String [ ] args) { SumReport sumReport = new SumReport ( ) ; sumReport. setPayTotalAmount ( new BigDecimal ( 2390000 ) ) ; sumReport. setJcAmountPer ( BigDecimal . valueOf ( 0.885 ) ) ; sumReport. setJcCountPer ( BigDecimal . valueOf ( 0.2394 ) ) ; sumReport. setLength ( BigDecimal . valueOf ( 1700.64003 ) ) ; List < SumReport > list = new ArrayList < > ( ) ; list. add ( sumReport) ; Map < String , UnitConvertType > map = new HashMap < > ( ) ; map. put ( "payTotalAmount" , UnitConvertType . TEN_THOUSAND_YUAN ) ; map. put ( "jcAmountPer" , UnitConvertType . PERCENTAGE ) ; map. put ( "jcCountPer" , UnitConvertType . PERMIL ) ; map. put ( "length" , UnitConvertType . ACCURACY ) ; unitMapConvert ( list, map) ; System . out. println ( list) ; }
}
2. 注解转换
- 定义注解
@Target ( ElementType . FIELD )
@Retention ( RetentionPolicy . RUNTIME )
public @interface UnitBigDecConvert { UnitConvertType name ( ) ;
}
- 解析注解
public static < T > void unitAnnotationConvert ( List < T > list) { list. forEach ( item -> { Field [ ] fields = item. getClass ( ) . getDeclaredFields ( ) ; for ( Field field : fields) { try { UnitBigDecConvert annotation = field. getAnnotation ( UnitBigDecConvert . class ) ; if ( annotation == null ) { continue ; } UnitConvertType name = annotation. name ( ) ; field. setAccessible ( true ) ; Object o = field. get ( item) ; if ( o != null ) { if ( name == UnitConvertType . PERCENTAGE ) { BigDecimal bigDecimal = ( ( BigDecimal ) o) . multiply ( BigDecimal . valueOf ( 100 ) ) ; field. set ( item, bigDecimal) ; } else if ( name == UnitConvertType . PERMIL ) { BigDecimal bigDecimal = ( ( BigDecimal ) o) . multiply ( BigDecimal . valueOf ( 1000 ) ) ; field. set ( item, bigDecimal) ; } else if ( name == UnitConvertType . TEN_THOUSAND_YUAN ) { BigDecimal bigDecimal = ( ( BigDecimal ) o) . divide ( BigDecimal . valueOf ( 10000 ) ) . setScale ( 2 , RoundingMode . HALF_UP ) ; field. set ( item, bigDecimal) ; } else if ( name == UnitConvertType . ACCURACY ) { BigDecimal bigDecimal = ( ( BigDecimal ) o) . setScale ( 2 , RoundingMode . HALF_UP ) ; field. set ( item, bigDecimal) ; } else { log. error ( "未知的单位转换类型" ) ; } } } catch ( IllegalAccessException e) { log. error ( "装换失败" , e) ; } } } ) ; } public static void main ( String [ ] args) { SumReport sumReport = new SumReport ( ) ; sumReport. setPayTotalAmount ( new BigDecimal ( 2390000 ) ) ; sumReport. setJcAmountPer ( BigDecimal . valueOf ( 0.885 ) ) ; sumReport. setJcCountPer ( BigDecimal . valueOf ( 0.2394 ) ) ; sumReport. setLength ( BigDecimal . valueOf ( 1700.64003 ) ) ; List < SumReport > list = new ArrayList < > ( ) ; list. add ( sumReport) ; unitAnnotationConvert ( list) ; System . out. println ( list) ; }