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
- 北京允许无人驾驶路测 难道是为方便圣诞老人送礼?
- 小程序新增多项功能,优化100多个功能点,堪称重磅!
- 人工智能的回报率:对冲基金嵌入机器学习?
- “人工智能助力上海科创中心建设”国际高峰论坛圆满结束
- 纳米白与Pandas
- 人工智能来了!实体零售会变成什么样?
- 全国计算机等级考试重大改革!新增Python科目
- 福特:相比美国人中国人更欢迎自动驾驶未来
- Zzreal的大数据笔记-SparkDay03
- 一文读懂公有链、私有链、联盟链
- 你开车低头看个微信消息都能被拍的清清楚楚,因为有这些黑科技
- 开启程序员世界的Hello World
- TensorFlow实战——图像分类神经网络模型
- SQL,一门不是语言的语言?
- 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 数组属性和方法