最近在项目中需要实现Excel表导出列名的国际化,完成@ExcelCollection对应实体类的excel国际化如何实现,从而想出了这种解决方法(excel导出使用的是jeecg的easyPoi)
例如:现在有一个实体类,比如People.class,里面有一个存放爱好的List集合属性,如何获取HoppyEntity.class
Public People {
private List<HoppyEntity> hoppyList = new ArrayList<HoppyEntity>();
public List<HoppyEntity> getHoppyList() {
return hoppyList;
}
public void setHoppyList(List<HoppiyEntity> hoppyList) {
this.hoppyList = hoppyList;
}
}
实现代码
//获取实体类中全部字段
Field[] fields = People.class.getDeclaredFields();
for (Field field : fields) {
//判断对应打印类是否是list集合,是则
if(field.getType().equals(List.class)) {
//返回字段的类型,ParameterizedType可以表示带有泛型参数的类型
ParameterizedType genericType = (ParameterizedType) field.getGenericType();
// 获取list集合中的泛型参数的类型
Class<?> genericClass = (Class<?>) genericType.getActualTypeArguments()[0];
}