1.导入依赖
<!-- https://mvnrepository.com/artifact/com.alibaba/easyexcel -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.1.1</version>
</dependency>
2.新建实体类,字段属性对应表中的列
public class User {
@ExcelProperty(value = "学生ID")
private int id;
@ExcelProperty(value = "学姓名")
private String name;
}
3.写操作测试
@Test
public void test1(){
ArrayList<User> users = new ArrayList<>();
for (int i = 0; i <10 ; i++) {
User user = new User();
user.setId(i);
user.setName("wang"+i);
users.add(user);
}
String file="E:\\test.xlsx";
EasyExcel.write(file,User.class).sheet("表1").doWrite(users);
}
3.结果
2.读操作
1.实体类注解列数下标
public class User {
@ExcelProperty(value = "学生ID",index = 0)
private int id;
@ExcelProperty(value = "学姓名",index = 1)
private String name;
}
2.自定义监听器
public class ExcelListener extends AnalysisEventListener<User> {
@Override
public void invoke(User user, AnalysisContext analysisContext) {
System.out.println(user);
}
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
System.out.println(analysisContext.currentReadHolder());
}
}
3.测试读操作
@Test
public void test2()
{
String file="E:\\test.xlsx";
EasyExcel.read(file,User.class, new ExcelListener()).sheet().doRead();
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!