关于excel导出列不强行全部导出
项目场景 :
在工作和开发中,往往会遇到一种情况:我们要导出一个列,来当做类名。但往往我们status,type等字段都是用数字来存放。如:status 0代表禁用,1代表正常…导出表格给客户,客户并不理解0和1代表什么。这个时候,就要在数据库做操作或者代码的方法体中做操作。先说结论使用@ExcelIgnoreUnannotated 来忽略没加@ExcelProperty注解的字段。
解决方法 :
第一种方法不提倡,在数据库中做操作可能会加大数据库负担,能在代码块中操作就尽量在代码块中操作。
接下来讲讲第二种
List<Order> list = XXXmapper.getCodeList();
if(!list.isEmpty){
for(Order order : list){
order.setStatusName(StatusEnum.parse(order.getStatus));
....
....
}
....
}
@ExcelIgnoreUnannotated
public class ExportOrderStatistics extends BaseRowModel{
/**
* 订单编号
*/
@ExcelProperty(value = "订单id", index = 0)
private String orderNo;
/**
* status 状态(数字类型)
*/
private Integer status;
/**
* status 状态(文字类型)
*/
@ExcelProperty(value = "订单状态", index = 1)
private String statusName;
.......
.......
.......
get/set
}
原因分析 :
这样操作可以把statusName给打印出来,但是用EasyExcel进行导出时,还是会将没用@ExcelProperty注解的字段如status给放到表格里。
原来是因为默认情况下Java类中的所有属性都添加读写,要在类的最上方加上@ExcelIgnoreUnannotated 注解。
这个注解的意思是:忽略不加@ExcelProperty的字段进行输出
参考API:
详情参考:阿里巴巴api文档