前言:
现在我们对“动态生成excel表头java导出”大约比较珍视,咱们都需要学习一些“动态生成excel表头java导出”的相关文章。那么小编在网络上搜集了一些对于“动态生成excel表头java导出””的相关资讯,希望朋友们能喜欢,姐妹们快快来学习一下吧!EasyExcel简介
Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及解压后存储都是在内存中完成的,内存消耗依然很大。easyexcel重写了poi对07版Excel的解析,能够原本一个3M的excel用POI sax依然需要100M左右内存降低到几M,并且再大的excel不会出现内存溢出,03版依赖POI的sax模式。在上层做了模型转换的封装,让使用者更加简单方便
动态表头
查看easyexcel支持导出表头设置方法,表头导出支持Class,List<List<String>> 类型。由于是动态表头 Class 类型不易封装,List<List<String>> 类型更加适合。
动态列
查看easyexcel支持数据导出格式,List.此处的List 是否支持List<List<String>>格式
跟踪代码,查找List 处理流程。经过跟踪,在创建excel之前,对类型进行了判断处理。
跟踪代码利器SequenceDiagram
怎样去跟踪代码?提供一个idea的插件SequenceDiagram,通过插件可以生成代码的调用流程,跟踪代码会更加方便。
以下是 easyexcel doWrite() 方法处理的时序图。
实现动态表头,动态列导出
表头。创建head方法,返回值类型List<List<String>>
动态列
private List<List<String>> data(){ List<List<String>> list = new ArrayList<List<String>>(); List<String> data0 = new ArrayList<String>(); data0.add("data1"); data0.add("data2"); data0.add("data3"); list.add(data0); return list;}
EasyExcel.write("动态表头xls").head(head()).sheet("模板").doWrite(data());
效果
总结
使用easyexcel 导出动态表头,列数据。只需构造符合List<List<String>> 格式数据即可。这与POI 直接使用起来更加的简单。
在使用第三方工具包时,有时由于文档不完整,需要跟踪源代码时,可以借助SequenceDiagram插件, 生成时序图,是代码跟踪更加清晰。
标签: #动态生成excel表头java导出