
EasyExcel 对于excel文件的读取与显示

介绍
EasyExcel是阿里巴巴开源的一个excel处理框架,以使用简单、节省内存著称。EasyExcel能大大减少占用内存的主要原因是在解析Excel时没有将文件数据一次性全部加载到内存中,而是从磁盘上一行行读取数据,逐个解析。
官网地址:EasyExcel官方文档 - 基于Java的Excel处理工具 | Easy Excel
EasyExcel 的主要特点如下:
1、高性能:EasyExcel 采用了异步导入导出的方式,并且底层使用 NIO 技术实现,使得其在导入导出大数据量时的性能非常高效。
2、易于使用:EasyExcel 提供了简单易用的 API,用户可以通过少量的代码即可实现复杂的 Excel 导入导出操作。
3、增强的功能“EasyExcel 支持多种格式的 Excel 文件导入导出,同时还提供了诸如合并单元格、数据校验、自定义样式等增强的功能。
4、可扩展性好:EasyExcel 具有良好的扩展性,用户可以通过自定义 Converter 对自定义类型进行转换,或者通过继承 EasyExcelListener 来自定义监听器实现更加灵活的需求。
maven的依赖
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>3.1.0</version>
</dependency>
主要是学项目的时候顺带记录一下
先创建实体类
@Data
public class CategoryExcelVo {
@ExcelProperty(value = "id" ,index = 0)
private Long id;
@ExcelProperty(value = "名称" ,index = 1)
private String name;
@ExcelProperty(value = "图片url" ,index = 2)
private String imageUrl ;
@ExcelProperty(value = "上级id" ,index = 3)
private Long parentId;
@ExcelProperty(value = "状态" ,index = 4)
private Integer status;
@ExcelProperty(value = "排序" ,index = 5)
private Integer orderNum;
}
首先是读操作
首先先创建一个监听器 例如 ExcelListener 其中必须继承 AnalysisEventListener 并且实现其中的 invoke(),doAfterAllAnalysed()方法
public class ExcelListener<T> extends AnalysisEventListener<T> {
private List<T> data = new ArrayList<>();
//读取excel内容
//从第二行开始读取,把每行内容封装到t对象里面
@Override
public void invoke(T t, AnalysisContext analysisContext) {
data.add(t);
}
public List<T> getData(){
return data;
}
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
}
}
读操作 (其中CategoryExcelVo是我自己创建的实体类,包含表格中的列,只不过好像影响不大)
//读操作
public static void read(){
//读取excel文件内容
String fileName = "G://test.xlsx";
//调用方法
ExcelListener<CategoryExcelVo> excelListener = new ExcelListener();
EasyExcel.read(fileName, CategoryExcelVo.class,excelListener).sheet().doRead();
List<CategoryExcelVo> data = excelListener.getData();
System.out.println(data);
}
读取文件
读取结果
[
CategoryExcelVo(id=1, name=2, imageUrl=3, parentId=4, status=5, orderNum=6),
CategoryExcelVo(id=12, name=22, imageUrl=33, parentId=44, status=55, orderNum=66),
CategoryExcelVo(id=31, name=null, imageUrl=null, parentId=null, status=null, orderNum=null)
]
接下来的是写操作
//写操作
public static void write(){
ArrayList<CategoryExcelVo> list = new ArrayList<>();
list.add(new CategoryExcelVo(1L , "数码办公" , "",0L, 1, 1)) ;
list.add(new CategoryExcelVo(11L , "华为手机" , "",1L, 1, 2)) ;
EasyExcel.write("G://test2.xlsx",CategoryExcelVo.class).sheet("分类的数据").doWrite(list);
}
其中wirte方法中
ExcelWriterBuilder write(String pathName, Class head)
第一个为文件路径,第二个为表头第一行的名称,我的为CategoryExcelVo中的实体类
.sheet()方法为表格的名称
具体的结果如图




更多推荐
所有评论(0)