MyExcel 2.3.0 版本发布,支持 SAX 方式导入

 惟心
发布于 2019年05月19日
收藏 89

MyExcel 是一个集导入、导出、加密 Excel 等多项功能的 Java 工具包。

导入:提供简便的API,读取Excel内容,并转化为List< Bean >。

导出:可快速导出海量数据的简单列表,可生成高复杂度布局的Excel,复杂布局指的是包含多种不规则合并单元格、背景色、字体大小、斜体等。

优点:

  • 可生成任意复杂表格:本工具使用迭代单元格方式进行excel绘制,可生成任意复杂度excel,自适应宽度、高度;
  • 零学习成本:使用html作为模板,学习成本几乎为零;
  • 支持常用背景色、边框、字体等样式设置:具体参见文档-Style-support(样式支持)部分;
  • 支持.XLS、.XLSX:支持生成.xls、.xlsx后缀的excel;
  • 支持公式导出:支持Excel模板中设置公式,降低服务端的计算量;
  • 支持低内存SXSSF模式:支持低内存的SXSSF模式,可利用极低的内存生成.xlsx;
  • 支持生产者消费者模式导出:支持生产者消费者模式导出,无需一次性获取所有数据,分批获取数据配合SXSSF模式实现真正意义上海量数据导出;
  • 支持多种模板引擎:已内置Freemarker、Groovy、Beetl等常用模板引擎Excel构建器(详情参见文档Getting started),推荐使用Beetl模板引擎(Beetl文档);
  • 提供默认Excel构建器,直接输出简单Excel:无需编写任何html,已内置默认模板,可直接根据POJO数据列表输出;
  • 支持一次生成多sheet:以table作为sheet单元,支持一份excel文档中多sheet导出;

本次更新如下:

  • 新增SaxExcelReader,支持sax方式读取,避免OOM;
  • 优化读取转换方式,性能提升;
  • DefaultExcelReader新增beanFilter方法,支持bean过滤;
  • 增加Bean反射缓存;
  • 升级jsoup为1.12.1,模板方式导出性能提升,内存占用降低;
// 方式一:全部读取后处理
List<ArtCrowd> result = SaxExcelReader.of(ArtCrowd.class)
        .sheet(0) // 如果为0,可省略该操作
        .rowFilter(row -> row.getRowNum() > 0) // 如无需过滤,可省略该操作,0代表第一行
        .read(path.toFile());

// 方式二:读取一行处理一行,可自行决定终止条件
SaxExcelReader.of(ArtCrowd.class)
        .sheet(0) // 如果为0,可省略该操作
        .rowFilter(row -> row.getRowNum() > 0) // 如无需过滤,可省略该操作,0代表第一行
        .readThen(path.toFile() ,artCrowd -> System.out.println(artCrowd.getName));

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;
}

具体使用,请移步:https://github.com/liaochong/myexcel/wiki

本站文章除注明转载外,均为本站原创或编译。欢迎任何形式的转载,但请务必注明出处,尊重他人劳动共创开源社区。
转载请注明:文章转载自 OSCHINA 社区 [http://www.oschina.net]
本文标题:MyExcel 2.3.0 版本发布,支持 SAX 方式导入
加载中

最新评论(5

惟心

引用来自“启程者”的评论

请问单元格内文本需要换行怎么处理
@启程者 手动加入\n\r换行,自动换行目前版本还不支持
启程者
启程者
请问单元格内文本需要换行怎么处理
XDOC-专注文档处理
XDOC-专注文档处理
功能强大,点赞!
三十六清风
看着不错,找个机会试试
周海生
周海生
赞!
返回顶部
顶部