MyExcel功能介绍
1、可生成任意复杂表格:本工具使用迭代单元格方式进行excel制作,可生成任意复杂度excel,自适应宽度、高度;
2、零学习成本:应用html作为模板,学习成本几乎为零;
3、支持常见背景色、边框、字体等款式设定:实际参见文档-款式支持部分;
4、支持.xls、.xlsx、.csv:支持生成.xls、.xlsx后缀的Excel以及.csv文件;
5、支持公式导出:支持Excel模板中设定公式,减少服务端的计算量;
6、支持低内存SXSSF模式:支持低内存的SXSSF模式,可利用极低的内存生成.xlsx;
7、支持生产者消费者模式导出:支持生产者消费者模式导出,无需一次性获得所有数据,分次读取数据配合SXSSF模式完成真正意义上海量信息导出;
8、支持多种模板引擎:已内置Freemarker、Groovy、Beetl、Thymeleaf等常见模板引擎Excel搭建器(详情参见文档Gettingstarted),推荐使用Beetl模板引擎(Beetl文档);
9、提供默认Excel搭建器,直接导出简易Excel:无需撰写任何html,已内置默认模板,可直接依据POJO数据列表导出;
10、支持一次生成多sheet:以table作为sheet模块,支持一份excel文档中有sheet导出;
11、支持Excel容量设置:支持设置Excel容量,到达容量后自动新建Excel,可搭建成zip压缩包导出。
MyExcel使用说明
导入示例
// (推荐)方式一:全部读取后处理,SAX模式,避免OOM,建议大量数据使用
List result = SaxExcelReader.of(ArtCrowd.class)
.sheet(0) // 0代表第一个,如果为0,可省略该操作
.rowFilter(row -> row.getRowNum() > 0) // 如无需过滤,可省略该操作,0代表第一行
.beanFilter(ArtCrowd::isDance) // bean过滤
.read(path.toFile());// 可接收inputStream
// (推荐)方式二:读取一行处理一行,可自行决定终止条件,SAX模式,避免OOM,建议大量数据使用
// readThen有两种重写接口,返回Boolean型接口允许在返回False情况下直接终止读取
SaxExcelReader.of(ArtCrowd.class)
.sheet(0) // 0代表第一个,如果为0,可省略该操作
.rowFilter(row -> row.getRowNum() > 0) // 如无需过滤,可省略该操作,0代表第一行
.beanFilter(ArtCrowd::isDance) // bean过滤
.readThen(path.toFile() ,artCrowd -> {System.out.println(artCrowd.getName);});// 可接收inputStream
public class ArtCrowd {
// index代表列索引,从0开始
@ExcelColumn(index = 0)
private String name;
@ExcelColumn(index = 1)
private String age;
@ExcelColumn(index = 2,dateFormatPattern="yyyy-MM-dd")
private Date birthday;
}
导出示例
List dataList = this.getDataList();
Workbook workbook = DefaultExcelBuilder.of(ArtCrowd.class)
.build(dataList);
AttachmentExportUtil.export(workbook, "艺术生信息", response);
// 加密导出
// AttachmentExportUtil.encryptExport(workbook, "艺术生信息", response,"123456");
}
番茄花园温馨提示:
1.下载完成软件以后请点击安装完成安装步骤。
2 软件同时支持32位64位运行环境。
3.仅支持windows系统安装软件。
4.本软件绿色无毒,请放心使用。