关于excel导出列不强行全部导出

关于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文档

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值