Excel 高效解析工具 EasyExcel 实践

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
云解析DNS,个人版 1个月
简介: EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel。

简介



EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel。


maven 依赖如下:


<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>3.0.5</version>
</dependency>


读 Execl 实践



数据读取代码如下:


  1. 先获取文件流,比如 test-data.xls;


  1. SkuModel是一个解析类;


  1. SkuModelReadListener中进行读取到的数据处理。


InputStream excelStream = ExcelToolMain.class.getClassLoader().getResourceAsStream("test-data.xls");
EasyExcel.read(excelStream, SkuModel.class, new SkuModelReadListener()).sheet().doRead();


写 Execl 实践


写数据代码如下:


  1. 首先我们需要设定写入文件的文件名


  1. 然后设置写入的数据类 SkuModel.


  1. data() 是用来获取数据的,其实就是返回,构建一个 List<SkuModel> 数据集合。


String fileName = ExcelToolMain.getPath() + "write" + System.currentTimeMillis() + ".xlsx";
EasyExcel.write(fileName, SkuModel.class).sheet().doWrite(data());


模板填充



为了解决 excel 模板样式的支持,我们可以使用模板方式来进行数据填充:


  1. 模板样式如下:


网络异常,图片无法展示
|


  1. 填充的效果如下:


网络异常,图片无法展示
|


  1. 代码如下:


// 文件名
String fileName = ExcelToolMain.getPath() + "fillOps" + System.currentTimeMillis() + ".xlsx";
// 数据对象
FillData fillData = new FillData();
fillData.setName("张三");
fillData.setNumber(5.2);
// 写入
EasyExcel.write(fileName).withTemplate(templateFileName).sheet().doFill(fillData);


文件追加



文件追加,感觉在 EasyExcel 中其实是一个流的多写,最后写完后关闭。代码如下:


ExcelWriter excelWriter = null;
try {
    // 这里 需要指定写用哪个class去写
    excelWriter = EasyExcel.write(fileName, SkuModel.class).build();
    // 这里注意 如果同一个sheet只要创建一次
    WriteSheet writeSheet = EasyExcel.writerSheet(sheet).build();
    for (int i = 0; i <  5; i++) {
        // 分页多次写
        excelWriter.write(data(), writeSheet);
    }
} finally {
    // 一定要 finish,表示文件写完毕,会关闭流
    excelWriter.finish();
}


总结


EasyExcel 是基于 POI 的 excel 解析工具,给我们提供了非常多的高效 API,解决了 POI 一些常见的问题。


相关文章
|
3天前
|
JSON 文字识别 数据格式
文本,文识11,解析OCR结果,paddOCR返回的数据,接口返回的数据有code,data,OCR返回是JSON的数据,得到JSON数据先安装依赖,Base64转换工具网站在21.14
文本,文识11,解析OCR结果,paddOCR返回的数据,接口返回的数据有code,data,OCR返回是JSON的数据,得到JSON数据先安装依赖,Base64转换工具网站在21.14
文本,文识11,解析OCR结果,paddOCR返回的数据,接口返回的数据有code,data,OCR返回是JSON的数据,得到JSON数据先安装依赖,Base64转换工具网站在21.14
|
6天前
|
设计模式 安全 PHP
PHP 7新特性深度解析与应用实践
【6月更文挑战第29天】在PHP 7的发布中,开发者社区迎来了一场性能与功能的盛宴。本文将深入挖掘PHP 7的新特性,从类型声明的强化到异常处理的改进,再到匿名类的引入,我们将一一探讨这些变化如何影响日常编码实践。通过实际代码示例,我们将展示如何有效利用这些新特性来编写更加清晰、高效和安全的PHP代码。
24 11
|
22小时前
|
SQL 运维 监控
MSSQL性能调优深度解析:索引优化策略、SQL查询优化技巧与高效并发管理实践
在Microsoft SQL Server(MSSQL)的运维与优化领域,性能调优是确保数据库高效运行、满足业务需求的关键环节
|
5天前
|
数据可视化 安全 Linux
探索Linux命令repo-graph:深入解析与应用实践
`repo-graph`是Linux的Yum-utils工具,用于可视化仓库中软件包的依赖关系,简化复杂网络管理。它通过分析元数据生成图形,支持自定义输出格式和特定包分析。例如,`repo-graph --repoid=updates`显示更新仓库的依赖,而`--packages=httpd`则专注httpd包。注意权限、复杂性和选择合适输出格式。定期分析和图形化展示是最佳实践。
|
5天前
|
缓存 安全 编译器
PHP 8新特性解析与性能优化实践
PHP 8的发布带来了一系列新特性和性能改进,本文将深入探讨PHP 8的关键特性,如JIT编译器、类型系统的增强和语言语法的优化,以及如何利用这些特性优化现有代码和提升应用性能。【7月更文挑战第2天】
8 1
|
5天前
|
安全 算法 编译器
PHP 8新特性深度解析与实践应用
【7月更文挑战第2天】本文深入探讨了PHP 8带来的革新性特性,包括JIT编译器的引入、联合类型和属性的声明等。文章不仅剖析了这些新特性背后的技术原理,还通过实例展示了如何在现实项目中有效利用它们来提升代码质量和执行效率。读者将获得对PHP 8新特性的全面认识以及如何在实际开发中灵活运用它们的实用指南。
8 1
|
8天前
|
Java 程序员 编译器
Java内存模型深度解析与实践优化策略
在多线程编程领域,Java内存模型(Java Memory Model, JMM)是确保并发程序正确性的基石。本文深入探讨JMM的工作原理,结合最新研究成果和实际案例,揭示高效同步策略和避免常见并发缺陷的方法。文章不仅阐述理论,更注重实践,旨在为Java开发者提供全面的内存模型应用指南。
|
23小时前
|
机器学习/深度学习 搜索推荐 算法
深度学习在推荐系统中的应用:技术解析与实践
【7月更文挑战第6天】深度学习在推荐系统中的应用为推荐算法的发展带来了新的机遇和挑战。通过深入理解深度学习的技术原理和应用场景,并结合具体的实践案例,我们可以更好地构建高效、准确的推荐系统,为用户提供更加个性化的推荐服务。
|
1天前
|
SQL 运维 数据库
MSSQL性能调优深度解析:索引优化策略、查询优化技巧与并发控制实践
在Microsoft SQL Server(MSSQL)的运维与优化旅程中,性能调优无疑是每位数据库管理员和开发者的必修课
|
2天前
|
编译器 测试技术 PHP
PHP 8新特性深度解析与实践
在PHP 8的发布中,我们见证了一系列创新特性的引入,这些特性不仅提升了语言的性能和安全性,还为开发者带来了更为便捷的编码体验。本文将深入探讨PHP 8中的JIT编译器、联合类型、命名参数、匹配表达式等关键特性,并通过实例演示如何在项目中有效利用这些新工具,以提升代码质量和开发效率。
6 0

推荐镜像

更多