4行Java代码导出百万行Excel?

假如我们有一个这样一个list:

List studentList 

Student类的字段简述如下:

class Student {String name, String idcard, int sex, ...}

如何快速的导出为Excel呢?

我们只想提供必要的信息:表名,表格的列名,要导出的Student字段名字:

String sheetName = "测试";
String[] columnNames = {"姓名", "身份证号", "性别", ...};
String[] classFieldNames = {"name", "idcard", "sex", ...};

我只想提供这三样信息,并不想做多余的编码工作,可以吗?

当然可以,我们可以引入一个Excel工具【
github.com/gaoice/easyexcel】来做这个事情:

XSSFWorkbook workbook = ExcelBuilder.createWorkbook(
 new SheetInfo(sheetName, columnNames, classFieldNames, studentList));

加上上面的定义,共4行代码,就可以导出一个如下形式的Excel。

4行Java代码导出百万行Excel?

这时候我们注意到性别列显示的是数字,明显不太合适,这时候怎么办呢?再加一个中文字段吗?并不用,我们有两种很简单的方式解决这个问题。

方法一:使用一个Map,做键值对映射。

SheetInfo sheetInfo = new SheetInfo(sheetName, columnNames, fieldNames, studentList);
Map sexMap = new HashMap<>();
sexMap.put(1, "男生");
sexMap.put(0, "女生");
sheetInfo.putConverter("sex", sexMap);

方法二:我们只需为这个字段编写一个Lambda表达式,就可以解决这个问题了。

sheetInfo.putConverter("sex", (sheetInfo1, o, listIndex, columnIndex) -> o.equals(1) ? "男生" : "女生");

方法一适合数据简单的映射,方法二可以用来对值进行任意操作。

现在得到表格

4行Java代码导出百万行Excel?

easyexcel使用了SXSSFWorkbook,支持导出大批量数据。

更多使用方法见github的说明,感谢阅读。


分享到:


相關文章: