编写匹配 Excel表格中数据的实体类
import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;
@Data
public class Stu {
//设置表头名称 索引
@ExcelProperty(value = "学生编号",index = 0)
private int sno;
//设置表头名称 索引
@ExcelProperty(value = "学生姓名",index = 1)
private String sname;
}
maven引入依赖
<dependencies>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.1.6</version>
</dependency>
</dependencies>
向Excel写入数据demo【封装的假数据 正常情况下 应该是从数据库查询】
import com.alibaba.excel.EasyExcel;
import com.atguigu.cmn.test.entity.Stu;
import java.util.ArrayList;
import java.util.List;
public class WriteTest {
public static void main(String[] args) {
String fileName = "E:\11.xlsx";
//文件路径 或 输入输出流 实体类 模板名称
EasyExcel.write(fileName,Stu.class).sheet("学生信息")
//要写入的数据
.doWrite(data());
}
//循环设置要添加的数据,最终封装到list集合中
private static List<Stu> data() {
List<Stu> list = new ArrayList<Stu>();
for (int i = 0; i < 10; i++) {
Stu data = new Stu();
data.setSno(i);
data.setSname("张三"+i);
list.add(data);
}
return list;
}
}
插入的数据
读取Excel数据demo【需要整合 读取监听器】
ExcelReadListener 监听器 用于从 Excel读取数据
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.atguigu.cmn.test.entity.Stu;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
public class ExcelReadListener extends AnalysisEventListener<Stu> {
//创建List集合 保存读取的数据
List<Stu> list = new ArrayList<>();
//一行一行的 读取excel内容 在这里可以操作向数据库插入数据
@Override
public void invoke(Stu stu, AnalysisContext analysisContext) {
System.out.println("stu读到的行 = " + stu);
list.add(stu);
}
//读取表头信息 当前方法 比读取信息的方法 先执行
@Override
public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
System.out.println("表头信息"+headMap);
}
//读取完后 执行
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
System.out.println("读取数据完成");
}
}
读取数据的代码
import com.alibaba.excel.EasyExcel;
import com.atguigu.cmn.test.entity.Stu;
public class ReadTest {
public static void main(String[] args) {
String fileName = "E:\11.xlsx";
//参数 文件路径 实体类 监听器 里面
EasyExcel.read(fileName, Stu.class, new ExcelReadListener()).sheet()
.doRead();
}
}
读取到的数据