Java对象属性填充默认值

Java对象属性填充默认值


背景:
需要将一个Java对象转换成JSON字符串, 对象中字段比较多, 里面也套了很多层,不初始化属性值的话变量的值就是空白( “ab”: {} ),初始化的话需要一层一层设置值,想找个简单的方法。


通过反射,初始化对象及属性(包含属性对象的属性…),再用工具转换成Json字符串时就可以保留完整key了。

代码如下(注: 只处理了简单的类型,别的没加,不能用自身,缓存啥的也没用,变量类型是本身类的话肯定会有问题 😦 ,大神用的时候自己改改吧 😃 ):

public static void main(String[] args) throws Exception {
    XxObject source = new XxObject ();
    Field[] declaredFields = XxObject.class.getDeclaredFields();
    for (Field declaredField : declaredFields) {
        fillField(declaredField, source);
    }
    String jsonString = JSON.toJSONString(source);
}

填充字段

private static void fillField(Field field, Object source) throws Exception {
        field.setAccessible(true);
        Class<?> fieldType = field.getType();
        if (fieldType == String.class) {
            // 字符串 -> ""
            field.set(source, "");
        } else if (fieldType == List.class) {
            // list, 根据泛型设置属性值, 没写没泛型的情况,没泛型加个空Object?
            ParameterizedTypeImpl genericType = (ParameterizedTypeImpl) field.getGenericType();
            Type[] actualTypeArguments = genericType.getActualTypeArguments();
            for (Type actualTypeArgument : actualTypeArguments) {
                String typeName = actualTypeArgument.getTypeName();
                // 来个对象, 再赋值成员变量
                Object arrayElement = Class.forName(typeName).newInstance();
                Field[] declaredFields = arrayElement.getClass().getDeclaredFields();
                for (Field declaredField : declaredFields) {
                    fillField(declaredField, arrayElement);
                }
                // 填充完, 设置属性
                List list = new ArrayList<>();
                list.add(arrayElement);
                field.set(source, list);
            }
        } else {
            // 对象, 初始化,再赋值成员变量
            Object object = field.getType().newInstance();
            Field[] declaredFields = object.getClass().getDeclaredFields();
            for (Field declaredField : declaredFields) {
                fillField(declaredField, object);
            }
            field.set(source, object);
        }
    }

没了 😃

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要根据Java对象属性生成Excel导入模板,可以使用Apache POI库来实现。 首先,需要定义一个JavaBean类,包含需要导入的数据的属性。例如,如果要导入一个包含姓名、年龄和性别的用户信息表,可以定义如下JavaBean类: ```java public class User { private String name; private int age; private String gender; // 省略getter和setter方法 } ``` 然后,可以使用POI库中的`Workbook`、`Sheet`和`Row`等类来创建Excel文件和填充数据。具体步骤如下: 1. 创建一个`Workbook`对象,可以选择创建`XSSFWorkbook`(用于处理xlsx格式)或`HSSFWorkbook`(用于处理xls格式)。 ```java Workbook workbook = new XSSFWorkbook(); ``` 2. 创建一个`Sheet`对象,并设置表格名称。 ```java Sheet sheet = workbook.createSheet("用户信息表"); ``` 3. 创建表头行,并设置表头单元格的值。 ```java Row headerRow = sheet.createRow(0); headerRow.createCell(0).setCellValue("姓名"); headerRow.createCell(1).setCellValue("年龄"); headerRow.createCell(2).setCellValue("性别"); ``` 4. 创建数据行,并设置数据单元格的值。 ```java User user = new User(); user.setName("张三"); user.setAge(20); user.setGender("男"); Row dataRow = sheet.createRow(1); dataRow.createCell(0).setCellValue(user.getName()); dataRow.createCell(1).setCellValue(user.getAge()); dataRow.createCell(2).setCellValue(user.getGender()); ``` 5. 将数据写入Excel文件中。 ```java FileOutputStream outputStream = new FileOutputStream("用户信息表.xlsx"); workbook.write(outputStream); outputStream.close(); ``` 通过以上步骤,就可以创建一个包含表头和数据的Excel导入模板。需要注意的是,如果JavaBean类中有很多属性,就需要在表头行中设置对应的列名,以便用户正确填写数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值