AbstractExcelWriterParameterBuilder提供了一些通用的方法,例如:
head(Class head):设置表头对应的数据类。
head(List<List<String>> head):设置表头为字符串列表。
includeColumnFiledNames(Set<String> includeColumnFiledNames):设置只导出指定的列名。
excludeColumnFiledNames(Set<String> excludeColumnFiledNames):设置忽略掉指定的列名。
useDefaultStyle(Boolean useDefaultStyle):设置是否使用默认样式。
registerWriteHandler(WriteHandler writeHandler):注册自定义的写入处理器。
public static void main(String[] args) {
// 生成文件路径
writeExcel("/Users/file/A.xlsx");
}
public static void writeExcel(String filePath) {
try {
// 写入数据
List<DataDemo> dataList = new ArrayList<>();
for (int i = 0; i < 10; i++) {
DataDemo data = new DataDemo();
data.setField1("A"+i);
data.setField2("B"+i);
data.setField3("C"+i);
dataList.add(data);
}
// excludeColumnFiledNames 依据列忽略
// excludeColumnIndexes 指定删除列index
// 还支持 includeColumnFiledNames 定义导出列
EasyExcel.write(filePath, DataDemo.class).excludeColumnFiledNames(Arrays.asList("field3")).sheet("用户").doWrite(dataList);
} catch (Exception e) {
e.printStackTrace();
}
}
@Data
static
class DataDemo {
@ExcelProperty("标题 1")
String field1;
@ExcelProperty("标题 2")
String field2;
@ExcelProperty("标题 3")
String field3;
}