序言:在开发Excel数据导入的时候,将导入的数据映射到List 泛型 集合中时,发现对象的 字符串 属性有很多空格,数据不规范,保存到数据库不好,需要对这些数据进行去空格操作,下面是具体的操作。
ObjectUtil工具类
import java .util.*;
import java.lang.reflect.Field;
public class ObjectUtil {
/**
* 对象字符串属性去空格
*/ public static void objectTo Trim (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 (IllegalAccess Exception 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]);
}
}
如果您有什么好的想法与方法,欢迎在评论区留言,我们一起讨论~