单位转换工具类
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) ;
}