java手写excel_一行代码完成 JAVA 的 EXCEL 读写——EasyExcel 的方法封装

本文介绍了如何利用阿里巴巴的EasyExcel库,通过简单的API实现Excel的读取和写入。提供了一个工具类ExcelUtil,只需一行代码即可完成读写操作。文章详细讲解了依赖引入、监听器、导出类的创建以及读取和导出Excel的示例代码,适用于基本的Excel处理需求。
摘要由CSDN通过智能技术生成

前段时间在 github 上发现了阿里的 EasyExcel 项目,觉得挺不错的,就写了一个简单的方法封装,做到只用一个函数就完成 Excel 的导入或者导。刚好前段时间更新修复了一些 BUG,就把我的这个封装分享出来,请多多指教

EasyExcel

EasyExcel 的 github 地址: https://github.com/alibaba/easyexcel

EasyExcel 的官方介绍:

cb9cd9965a63?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

可以看到 EasyExcel 最大的特点就是使用内存少,当然现在它的功能还比较简单,能够面对的复杂场景比较少,不过基本的读写完全可以满足。

一. 依赖

首先是添加该项目的依赖,目前的版本是 1.1.2-beta4

com.alibaba

easyexcel

1.1.2-beta4

二. 需要的类

cb9cd9965a63?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

1. ExcelUtil

工具类,可以直接调用该工具类的方法完成 Excel 的读或者写

2. ExcelListener

监听类,可以根据需要与自己的情况,自定义处理获取到的数据,我这里只是简单地把数据添加到一个 List 里面。

public class ExcelListener extends AnalysisEventListener {

//自定义用于暂时存储data。

//可以通过实例获取该值

private List datas = new ArrayList<>();

/**

* 通过 AnalysisContext 对象还可以获取当前 sheet,当前行等数据

*/

@Override

public void invoke(Object object, AnalysisContext context) {

//数据存储到list,供批量处理,或后续自己业务逻辑处理。

datas.add(object);

//根据自己业务做处理

doSomething(object);

}

private void doSomething(Object object) {

}

@Override

public void doAfterAllAnalysed(AnalysisContext context) {

/*

datas.clear();

解析结束销毁不用的资源

*/

}

public List getDatas() {

return datas;

}

public void setDatas(List datas) {

this.datas = datas;

}

}

3. ExcelWriterFactroy

用于导出多个 sheet 的 Excel,通过多次调用 write 方法写入多个 sheet

4. ExcelException

捕获相关 Exception

三. 读取 Excel

读取 Excel 时只需要调用 ExcelUtil.readExcel() 方法

@RequestMapping(value = "readExcel", method = RequestMethod.POST)

public Object readExcel(MultipartFile excel) {

return ExcelUtil.readExcel(excel, new ImportInfo());

}

其中 excel 是 MultipartFile 类型的文件对象,而 new ImportInfo() 是该 Excel 所映射的实体对象,需要继承 BaseRowModel 类,如:

public class ImportInfo extends BaseRowModel {

@ExcelProperty(index = 0)

private String name;

@ExcelProperty(index = 1)

private String age;

@ExcelProperty(index = 2)

private String email;

/*

作为 excel 的模型映射,需要 setter 方法

*/

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public String getAge() {

return age;

}

public void setAge(String age) {

this.age = age;

}

public String getEmail() {

return email;

}

public void setEmail(String email) {

this.email = email;

}

}

作为映射实体类,通过 @ExcelProperty 注解与 index 变量可以标注成员变量所映射的列,同时不可缺少 setter 方法

四. 导出 Excel

1. 导出的 Excel 只拥有一个 sheet

只需要调用 ExcelUtil.writeExcelWithSheets() 方法:

@RequestMapping(value = "writeExcel", method = RequestMethod.GET)

public void writeExcel(HttpServletResponse response) throws IOException {

List list = getList();

String fileName = "一个 Excel 文件";

String sheetName = "第一个 sheet";

ExcelUtil.writeExcel(response, list, fileName, sheetName, new ExportInfo());

}

fileName,sheetName 分别是导出文件的文件名和 sheet 名,new ExportInfo() 为导出数据的映射实体对象,list 为导出数据。

对于映射实体类,可以根据需要通过 @ExcelProperty 注解自定义表头,当然同样需要继承 BaseRowModel 类,如:

public class ExportInfo extends BaseRowModel {

@ExcelProperty(value = "姓名" ,index = 0)

private String name;

@ExcelProperty(value = "年龄",index = 1)

private String age;

@ExcelProperty(value = "邮箱",index = 2)

private String email;

@ExcelProperty(value = "地址",index = 3)

private String address;

}

value 为列名,index 为列的序号

如果需要复杂一点,可以实现如下图的效果:

cb9cd9965a63?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

对应的实体类写法如下:

public class MultiLineHeadExcelModel extends BaseRowModel {

@ExcelProperty(value = {"表头1","表头1","表头31"},index = 0)

private String p1;

@ExcelProperty(value = {"表头1","表头1","表头32"},index = 1)

private String p2;

@ExcelProperty(value = {"表头3","表头3","表头3"},index = 2)

private int p3;

@ExcelProperty(value = {"表头4","表头4","表头4"},index = 3)

private long p4;

@ExcelProperty(value = {"表头5","表头51","表头52"},index = 4)

private String p5;

@ExcelProperty(value = {"表头6","表头61","表头611"},index = 5)

private String p6;

@ExcelProperty(value = {"表头6","表头61","表头612"},index = 6)

private String p7;

@ExcelProperty(value = {"表头6","表头62","表头621"},index = 7)

private String p8;

@ExcelProperty(value = {"表头6","表头62","表头622"},index = 8)

private String p9;

}

2. 导出的 Excel 拥有多个 sheet

调用 ExcelUtil.writeExcelWithSheets() 处理第一个 sheet,之后调用 write() 方法依次处理之后的 sheet,最后使用 finish() 方法结束

public void writeExcelWithSheets(HttpServletResponse response) throws IOException {

List list = getList();

String fileName = "一个 Excel 文件";

String sheetName1 = "第一个 sheet";

String sheetName2 = "第二个 sheet";

String sheetName3 = "第三个 sheet";

ExcelUtil.writeExcelWithSheets(response, list, fileName, sheetName1, new ExportInfo())

.write(list, sheetName2, new ExportInfo())

.write(list, sheetName3, new ExportInfo())

.finish();

}

write 方法的参数为当前 sheet 的 list 数据,当前 sheet 名以及对应的映射类

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值