使用Java操作Excel

1.引入依赖
xml 复制代码
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>3.1.3</version>
        </dependency>
2.编写实体类,用注解映射Excel表格属性
java 复制代码
@Data
public class Excel {
    @ExcelProperty("用户名")
    @ColumnWidth(20)
    private String name;
    @ExcelProperty("性别")
    @ColumnWidth(20)
    private String sex;
}
3.编写Java代码向Excel表格写入文件
  • 定义Excel路径
java 复制代码
  String fileName = "用户信息.xlsx";
  • 准备好要写入Excel文件里的内容
java 复制代码
    private static List<Excel> data() {
        // 准备一些测试数据
        List<Excel> list = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            Excel excel = new Excel();
            excel.setName("张三" + i);
            excel.setSex("男");
            list.add(excel);
        }
        return list;
    }
  • 在测试类里调用EasyExce里的的静态方法传入文件路径,实体类,要写入的数据执行写入数据操作即可完成Excel内容写入工作
4.编写Java代码读取Excel里的数据
  • 创建监听器类来处理每一行的数据
java 复制代码
public class ExcelListener extends AnalysisEventListener<Excel> {
    private List<Excel> dataList = new ArrayList<>();

    @Override
    public void invoke(Excel data, AnalysisContext context) {
        dataList.add(data);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext context) {
        // 所有数据解析完成后的操作
    }

    public List<Excel> getDataList() {
        return dataList;
    }
}
  • 使用 EasyExcel来读取文件

  • 定义文件路径

java 复制代码
String fileName = "用户信息.xlsx";
  • 创建监视器执行读取方法
java 复制代码
ExcelListener listener = new ExcelListener();
EasyExcel.read(fileName, UserData.class, listener).sheet().doRead();
  • 访问读取的数据
java 复制代码
List<UserData> dataList = listener.getDataList();
for (UserData userData : dataList) {
System.out.println("用户名:" + userData.getUsername() + ", 年龄:" + userData.getAge());}
相关推荐
无风听海12 分钟前
多租户系统中的 OIDC:Discovery 端点与联合登录的深度实践
后端·python·flask
CTA终结者43 分钟前
期货量化主力换月程序怎么移仓:天勤 underlying_symbol 与任务切换
python·区块链
马士兵教育1 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习
snow@li1 小时前
Java:理解 Gradle / 后端项目的管家 / 打包SpringBoot 应用 / 完成编译、下载依赖、运行测试、打包 JAR/WAR / 速查表
java
KaMeidebaby1 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
Cloud_Shy6181 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 30 - 32)
开发语言·人工智能·笔记·python·学习方法
云烟成雨TD1 小时前
Spring AI 1.x 系列【57】动态工具发现:Tool Search Tool
java·人工智能·spring
zfoo-framework2 小时前
[修改代码使用]codex官方app中使用中转(不需要cc-switch) 1.config.toml 2.sk方式登录
java
天佑木枫2 小时前
15天Python入门系列 · 序
开发语言·python
happylifetree2 小时前
Python017-第二章15.数据容器-dict常用操作
python