动态类groovy根据字符串动态生成类(导出excel使用)

在业务场景中,为了应对导出Excel时列数不固定的灵活性需求,可以使用Groovy根据配置动态生成类。该方法首先通过GroovyClassLoader解析字符串为类,然后实例化动态类对象,并利用反射设置成员变量的值。最后,可以借助反射读取和设置对象的属性,以实现动态导出Excel的目的。
摘要由CSDN通过智能技术生成

业务上可以通过配置来改变导出的excel列,这边导出excel的列不固定的情况下,考虑下来比较方便的办法是根据配置来生成动态类,根据动态类来导出excel。
示例代码中@Excel注解为导出工具类(ruoyi),主要点在于动态生成类供导出使用。

用groovy生成动态类整个过程大致是通过以下流程进行的:
// 1.通过Groovy将字符串动态生成为动态类。groovy生成的类和普通的类没有任何区别,属性、方法、注解等都可以通过反射操作
GroovyClassLoader groovyClassLoader = new GroovyClassLoader();
Class<?> clazz = groovyClassLoader.parseClass(dynamicClassStr);
// 2.新建一个动态类对象
Object obj = clazz.newInstance();
// 3.通过反射,获取该类的成员变量,给对象设置值.
// 通过反射获取字段Field是类的,该类的对象都可以用。如:f.set(obj, value),f.set(obj1, value)
// 不用每个对象操作成员变量都重新获取Field,在需要反射操作泛型集合对象的时候,在获取到类class时,生成一次,集合中每个对象都可以用。
String fieldName = “message”;
Field f = c.getDeclaredField(fieldName);
// 取消语言访问检查
f.setAccessible(true);
// 4.给变量赋值
f.set(obj, “hello~”);
// 5.读值输出
System.out.println(f.get(obj));

实际处理:

// 获取配置的导出列信息
List<String> configList = mapper.select...();
GroovyClassLoader gcl = new GroovyClassLoader
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值