有时候我们需要进行一些excel表格的操作,不管是读取表格数据还是往表格写数据,之前都是使用poi去操作,需要自己获取流然后再一行一行的写,感觉还是有点麻烦,今天我们介绍一个使用起来比较方便的工具,就是easyexcel,下面我介绍一下基本用法,大家会发现对于一般的读写操作,会很方便
- 首先创建一个简单的maven工程,并将需要的依赖引入
<!--xls-->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.17</version>
</dependency>
<!--xlsx-->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.17</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.1.1</version>
</dependency>
- 引入依赖后,就可以进行编码实践了,创建一个对应的简单实体类
public class DemoData {
private Integer sno;
private String sname;
public DemoData(){}
public DemoData(Integer sno, String sname) {
this.sno = sno;
this.sname = sname;
}
public Integer getSno() {
return sno;
}
public void setSno(Integer sno) {
this.sno = sno;
}
public String getSname() {
return sname;
}
public void setSname(String sname) {
this.sname = sname;
}
@Override
public String toString() {
return "DemoData{" +
"sno=" + sno +
", sname='" + sname + '\'' +
'}';
}
}
- 然后创建一个测试类,先测试一些,写操作
public class TestEasyExcel {
public static void main(String[] args) {
//实现excel写操作
//1 设置写入文件夹地址和excel文件名称
String fileName = "/Users/liuzhenyu/workspace/exceltest/src/main/java/write.xlsx";
//2 调用easyexcel里面的方法实现写操作
//write方法两个参数:第一个参数文件路径名称,第二个参数实体类class
EasyExcel.write(fileName, DemoData.class).sheet("学生列表").doWrite(getData());
}
//创建方法返回list集合
private static List<DemoData> getData(){
List<DemoData> list = new ArrayList<DemoData>();
for(int i=0; i<10; i++){
DemoData data = new DemoData(i,"lucy"+i);
list.add(data);
}
return list;
}
}
- 执行之后,去文件中看一下是否写进去了,可以看到完美写入,就是这么简单,哈哈
- 下面我们来实现一下读的操作,正好读取我们刚刚写的那个文件,将读取的结果打印在控制台,相对于写操作,读操作还需要增加一个监听类,在监听类中获取表格的数据
public class ExcelListener extends AnalysisEventListener<DemoData> {
//一行一行读取excel内容
public void invoke(DemoData demoData, AnalysisContext analysisContext) {
System.out.println("****"+demoData);
}
//读取表头内容
@Override
public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
System.out.println("表头:" + headMap);
}
//读取完成之后
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
System.out.println("已读取完成");
}
}
- 然后在测试类中只要加写两行代码就可以了
public class TestEasyExcel {
public static void main(String[] args) {
//实现excel写操作
//1 设置写入文件夹地址和excel文件名称
String fileName = "/Users/liuzhenyu/workspace/exceltest/src/main/java/write.xlsx";
//2 调用easyexcel里面的方法实现写操作
//write方法两个参数:第一个参数文件路径名称,第二个参数实体类class
//EasyExcel.write(fileName, DemoData.class).sheet("学生列表").doWrite(getData());
//实现excel读操作
EasyExcel.read(fileName, DemoData.class, new ExcelListener()).sheet().doRead();
}
//创建方法返回list集合
/*private static List<DemoData> getData(){
List<DemoData> list = new ArrayList<DemoData>();
for(int i=0; i<10; i++){
DemoData data = new DemoData(i,"lucy"+i);
list.add(data);
}
return list;
}*/
}
- 看一下控制台显示,成功了,是不是很简单,快去试试吧