POIEasyExcel
时间:2022-07-25
本文章向大家介绍POIEasyExcel,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
POI与EasyExcel
- 数据导出excel
- 数据导入程序
POI
- 数据加入内存再操作
- 消耗内存
// 工作簿 2003 65535行
Workbook workbook = new HSSFWorkbook();
// 工作簿 2007 无限制,但耗时较长
Workbook workbook = new XSSFWorkbook();
// 无限制,大量数据速度也快,但会产生临时文件
// 工作表
Sheet sheet = workbook.createSheet("sheet1");
// 行
Row row1 = sheet.createRow(0);
// 列 (1,1)
Cell cell1 = row1.createCell(0);
cell1.setCellValue("1,1");
Workbook workbook = new SXSSFWorkbook();
// 清除临时文件
((SXSSFWorkbook)workbook).dispose();
读取
- 注意类型问题,程序中获取时按照类型获取
<!--03-->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.1.0</version>
</dependency>
<!--07-->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.1.0</version>
</dependency>
EasyExcel
- 逐行操作
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.2.6</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
</dependency>
@Data
@NoArgsConstructor
@AllArgsConstructor
public class User {
@ExcelProperty("id")
private Integer id;
@ExcelProperty("用户名")
private String name;
//@ExcelIgnore 忽略属性
@ExcelProperty("用户密码")
private String password;
public static List<User> create(){
List<User> list = new ArrayList<User>();
User u = new User(1,"dzf", "123");
User u2 = new User(1,"dzf","123456");
User u3 = new User(2,"gyg","1234");
list.add(u);
list.add(u);
list.add(u3);
return list;
}
public static class UserListener extends AnalysisEventListener<User> {
List<User> list = new ArrayList<User>();
@Override
public void invoke(User data, AnalysisContext context) {
System.out.println(data);
}
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
System.out.println("读入完成");
}
}
}
// 写
List<User> list = User.create();
EasyExcel.write("D:/desktop/xxx.xlsx",User.class).sheet("sheetname").doWrite(list);
// 读
EasyExcel.read("D:/desktop/xxx.xlsx",User.class,new User.UserListener()).sheet("sheetname").doRead();
https://alibaba-easyexcel.github.io/index.html
- Tensorflow动态seq2seq使用总结
- 卷积神经网络中PET/CT图像的纹理特征提取
- 深入剖析Spring(四)——AOP
- Java并发编程的艺术(十二)——线程安全
- 用 LSTM 做时间序列预测的一个小例子
- Java并发编程的艺术(十一)——线程池(2)
- Java并发编程的艺术(十)——线程池(1)
- Tensorflow on Spark爬坑指南
- Boost asio 官方教程
- 0基础教你搭建一套可自动化构建的微服务框架(SpringBoot+Dubbo+Docker+Jenkins)
- 柴毛毛大话设计模式——开发常用的设计模式梳理
- Redis源码分析(四)——Redis数据结构-整数集合
- Redis源码分析(三)——Redis数据结构-字典
- Redis源码分析(二)——Redis数据结构-链表
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Working with Errors in Go 1.13
- Hadoop技术(二)资源管理器YARN和分布式计算框架MapReduce
- CDH——Cloudera’s Distribution Including Apache Hadoop
- 【go】剑指offer:用26个英文字母组合表示列数
- Flink——运行在数据流上的有状态计算框架和处理引擎
- goland破解教程
- HTTP接口设计
- NSQ分布式消息基础入门
- 【golang】剑指offer 最大n位数
- Spark提交Jar任务警告: Initial job has not accepted any resources;
- Defer,Panic,and Recover
- Spark——底层操作RDD,基于内存处理数据的计算引擎
- Go 项目最佳实践
- 虚拟机更换JDK版本步骤(Hadoop集群)
- JavaSE重点复习