前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >POIEasyExcel

POIEasyExcel

作者头像
Dean0731
发布2020-09-22 11:06:30
3790
发布2020-09-22 11:06:30
举报
文章被收录于专栏:blog-技术博客blog-技术博客

POI与EasyExcel

  • 数据导出excel
  • 数据导入程序

POI

  • 数据加入内存再操作
  • 消耗内存
代码语言:javascript
复制
// 工作簿 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(); 

读取

  • 注意类型问题,程序中获取时按照类型获取
代码语言:javascript
复制
        <!--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

  • 逐行操作
代码语言:javascript
复制
<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>
代码语言:javascript
复制
@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("读入完成");
		}

	}
}
代码语言:javascript
复制
// 写
List<User> list = User.create();
EasyExcel.write("D:/desktop/xxx.xlsx",User.class).sheet("sheetname").doWrite(list);
代码语言:javascript
复制
// 读
EasyExcel.read("D:/desktop/xxx.xlsx",User.class,new User.UserListener()).sheet("sheetname").doRead();

https://alibaba-easyexcel.github.io/index.html

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-19 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • POI与EasyExcel
  • POI
  • EasyExcel
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档