Java 对象所有字符串属性去空格

序言:在开发Excel数据导入的时候,将导入的数据映射到List泛型集合中时,发现对象的字符串属性有很多空格,数据不规范,保存到数据库不好,需要对这些数据进行去空格操作,下面是具体的操作。

ObjectUtil工具类

import java.util.*;
import java.lang.reflect.Field;

public class ObjectUtil {
	/**
     * 对象字符串属性去空格
     */
    public static void objectToTrim(Object object) {
        Map<String,String> map = new HashMap<>();
        Field[] fields = getAllFields(object);
        for (Field field : fields){
            String type = field.getType().getCanonicalName();
            if ("java.lang.String".equals(type)){
                field.setAccessible(true);
                Object getObject = null;

                try {
                    getObject = field.get(object);
                } catch (IllegalAccessException e) {
                    e.printStackTrace();
                }

                if (getObject != null) {
                    String trim = getObject.toString().replace(" ","");
                    map.put(field.getName(), trim);
                }
            }
        }

        for (Field field : fields) {
            if (map.get(field.getName()) != null){
                String s = map.get(field.getName());
                field.setAccessible(true);
                try {
                    field.set(object, s);
                } catch (IllegalAccessException e) {
                    e.printStackTrace();
                }
            }
        }
    }

    /**
     * 获取子类和父类所有字段信息
     */
    private static Field[] getAllFields(Object object) {
        Class clazz = object.getClass();

        List<Field[]> fieldsList = new ArrayList<>();  // 保存属性对象数组到列表
        while (clazz != null) {  // 遍历所有父类字节码对象
            Field[] declaredFields = clazz.getDeclaredFields();  // 获取字节码对象的属性对象数组
            fieldsList.add(declaredFields);

            clazz = clazz.getSuperclass();  // 获得父类的字节码对象
        }

        List<Field> allFields = new ArrayList<>();
        for (Field[] fields : fieldsList) {
            allFields.addAll(Arrays.asList(fields));
        }

        return allFields.toArray(new Field[0]);
    }
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值