网站首页 > 博客文章 正文
假如我们有一个这样一个list:
List<Student> 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。
这时候我们注意到性别列显示的是数字,明显不太合适,这时候怎么办呢?再加一个中文字段吗?并不用,我们有两种很简单的方式解决这个问题。
方法一:使用一个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) ? "男生" : "女生");
方法一适合数据简单的映射,方法二可以用来对值进行任意操作。
现在得到表格
easyexcel使用了SXSSFWorkbook,支持导出大批量数据。
更多使用方法见github的说明,感谢阅读。
- 上一篇: Excel 导入导出解决方案 Easy-POI
- 下一篇: java在处理大数据的时候一些小技巧
猜你喜欢
- 2024-10-11 搞定Excel繁琐操作:一起轻松掌握EasyExcel的使用技巧
- 2024-10-11 「软件更新」MyExcel 3.0.0.RC 发布:重构&性能提升
- 2024-10-11 多功能 Excel 工具包 MyExcel(excel工具大全)
- 2024-10-11 Java使用poi进行excel的导入操作(java poi操作excel)
- 2024-10-11 SpringBoot实现Excel导入导出,好用到爆,POI可以扔掉了
- 2024-10-11 AI领域的“新常态”:面对“AI幻觉”,我们该怎么办?
- 2024-10-11 Java8如何让Excel的读写变得更加简单高效
- 2024-10-11 JAVA POI实现大数据量excel文件读写及导出
- 2024-10-11 java使用导出百万级别数据?(java百万数据excel导入)
- 2024-10-11 高级Java研发师在解决大数据问题上的一些技巧
你 发表评论:
欢迎- 最近发表
-
- 给3D Slicer添加Python第三方插件库
- Python自动化——pytest常用插件详解
- Pycharm下安装MicroPython Tools插件(ESP32开发板)
- IntelliJ IDEA 2025.1.3 发布(idea 2020)
- IDEA+Continue插件+DeepSeek:开发者效率飙升的「三体组合」!
- Cursor:提升Python开发效率的必备IDE及插件安装指南
- 日本旅行时想借厕所、买香烟怎么办?便利商店里能解决大问题!
- 11天!日本史上最长黄金周来了!旅游万金句总结!
- 北川景子&DAIGO缘定1.11 召开记者会宣布结婚
- PIKO‘PPAP’ 洗脑歌登上美国告示牌
- 标签列表
-
- ifneq (61)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)