文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

easyExcel中如何读取Excel表头

2023-06-30 18:45

关注

今天小编给大家分享一下easyExcel中如何读取Excel表头的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

1 环境准备

准备一个可以正常访问的SpringBoot项目.

1 添加pom

        <!-- https://mvnrepository.com/artifact/com.alibaba/easyexcel -->        <dependency>            <groupId>com.alibaba</groupId>            <artifactId>easyexcel</artifactId>            <version>3.0.5</version>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-web</artifactId>        </dependency>        <dependency>            <groupId>org.projectlombok</groupId>            <artifactId>lombok</artifactId>            <optional>true</optional>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-test</artifactId>            <scope>test</scope>        </dependency>

2 添加dto对象

// 表格对应实体类@Datapublic class EasyExcelDemo {    @ExcelProperty("标题")    private String string;    @ExcelProperty("日期")    private Date date;    @ExcelProperty("金额")    private Double money;        @ExcelIgnore    private String name;}
// 返回对象@Datapublic class Resp {    private List<EasyExcelDemo> importList;}

3 准备一个控制器

@RestController@RequestMapping("/easyExcel")@Slf4jpublic class EasyExcelController {        @PostMapping("/upload")    public void upload(@RequestParam("file") MultipartFile file) throws IOException {    // 读取Excel            EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,                new EasyExcelListener()).sheet().headRowNumber(1).doRead();        // 从监听中获取结果集        Resp resp = EasyExcelListener.RESP.get();        List<EasyExcelDemo> importList = resp.getImportList();        log.info("导入集合 list = {}", importList);        // 清除数据        EasyExcelListener.RESP.remove();    }    }

4 准备一个监听类

@Slf4jpublic class EasyExcelListener extends AnalysisEventListener<EasyExcelDemo> {    public static List<EasyExcelDemo> importList = new ArrayList<>();    public static final ThreadLocal<Resp> RESP = new ThreadLocal<>();    @Override    public void invoke(EasyExcelDemo data, AnalysisContext context) {        log.info("解析到的一条数据: excelRow = {}", data);        importList.add(data);    }    @Override    public void doAfterAllAnalysed(AnalysisContext context) {        // 解析完所有excel行, 保存到数据库或进行业务处理        log.info("解析的所有数据 list = {}", importList);        Resp resp = new Resp();        resp.setImportList(importList);        RESP.set(resp);    }    @Override    public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {        log.info("表头数据 excelHead= {}", headMap);    }}

2 单表头Excel

单表头Excel, 即Excel的表头只有一行.

easyExcel中如何读取Excel表头

如上单行表头, 在读取时,在EasyExcel读取时设置headRowNumber属性,表示Excel的表头的行数,默认为1,设置为1时,表示第一行是表头,从第二行是表数据

 EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,                new EasyExcelListener()).sheet().headRowNumber(1).doRead();

使用postman上传excel查看结果:

读取到Excel的表头

easyExcel中如何读取Excel表头

读取到Excel的表数据

easyExcel中如何读取Excel表头

3 多表头Excel

多表头Excel, 即Excel的表头有多行.

easyExcel中如何读取Excel表头

如上单行表头, 在读取时,在EasyExcel读取时设置headRowNumber属性,表示Excel的表头的行数,设置为2时,表示第二和之前行都是表头.

EasyExcel.read(file.getInputStream(), EasyExcelDemo.class, new EasyExcelListener()).sheet().headRowNumber(2).doRead(); EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,                new EasyExcelListener()).sheet().headRowNumber(2).doRead();

使用postman上传excel查看结果:

读取到Excel的表头, 读取到第一行

easyExcel中如何读取Excel表头

接着读取表头第二行

easyExcel中如何读取Excel表头

读取到Excel的表数据

easyExcel中如何读取Excel表头

以上就是“easyExcel中如何读取Excel表头”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯