最近项目需要导出Excel, 而且Excel的表头不固定, 还涉及表头合并和样式调整, 以及某些列需要千位分隔符和百分比, 在Github上找到了阿里开源的Easy-Excel
引入依赖
com.alibaba
easyexcel
1.1.2-beta5
定义需要导出的类
@ExcelProperty注解式用来标记字段在Excel中的表头, value值支持多级表头, 用一级表头一致框架自动会对表头进行合并, index是用来标记字段在Excel中的顺序(不是Excel中的位置), 因为项目实际需求中有几个字段是可选导出的, 所以index没有设置成连续的; 其次, 导出的字段中总量要求有千位分隔符, 两个满足率字段要求有百分号, 因此需要单独设置单元格样式
@EqualsAndHashCode(callSuper = true)
@Data
@Accessors(chain = true)
public class BasePurchaseExecutionResponse extends BaseRowModel {
/**
* 序号
*/
@ExcelProperty(value = {"", "", "序号"}, index = 0)
private String num;
/**
* 供应商类型
*/
@ExcelProperty(value = {"", "", "供应商类型"}, index = 1)
private String supplierType;
/**
* 品牌
<