iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Hutool Java工具类库_ExcelUtil怎么使用
  • 504
分享到

Hutool Java工具类库_ExcelUtil怎么使用

2023-06-21 21:06:39 504人浏览 薄情痞子
摘要

这篇文章主要介绍“Hutool Java工具类库_excelUtil怎么使用”,在日常操作中,相信很多人在Hutool Java工具类库_ExcelUtil怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作

这篇文章主要介绍“Hutool Java工具类库_excelUtil怎么使用”,在日常操作中,相信很多人在Hutool Java工具类库_ExcelUtil怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Hutool Java工具类库_ExcelUtil怎么使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

    Hutool Java工具类库_ExcelUtil

    依赖

    <!--Hutool Java工具包-->    <dependency>       <groupId>cn.hutool</groupId>       <artifactId>hutool-all</artifactId>       <version>5.4.5</version> </dependency>

    ExcelUtil

    从文件中读取Excel为ExcelReader

    ExcelReader reader = ExcelUtil.getReader(FileUtil.file("test.xlsx"));

    从流中读取Excel为ExcelReader

    ExcelReader reader = ExcelUtil.getReader(ResourceUtil.getStream("aaa.xlsx"));

    读取指定的sheet

    ExcelReader reader;//通过sheet编号获取reader = ExcelUtil.getReader(FileUtil.file("test.xlsx"), 0);//通过sheet名获取reader = ExcelUtil.getReader(FileUtil.file("test.xlsx"), "sheet1");

    ExcelReader

    读取Excel中所有行和列,都用列表表示

    ExcelReader reader = ExcelUtil.getReader("d:/aaa.xlsx");List<List<Object>> readAll = reader.read();

    读取为Map列表,默认第一行为标题行,Map中的key为标题,value为标题对应的单元格值

    ExcelReader reader = ExcelUtil.getReader("d:/aaa.xlsx");List<Map<String,Object>> readAll = reader.readAll();

    读取为Bean列表,Bean中的字段名为标题,字段值为标题对应的单元格值

    ExcelReader reader = ExcelUtil.getReader("d:/aaa.xlsx");List<Person> all = reader.readAll(Person.class);

    ExcelWriter

    Hutool将Excel写出封装为ExcelWriter,原理为包装了Workbook对象,每次调用merge(合并单元格)或者write(写出数据)方法后只是将数据写入到Workbook,并不写出文件,只有调用flush或者close方法后才会真正写出文件。

    由于机制原因,在写出结束后需要关闭ExcelWriter对象,调用close方法即可关闭,此时才会释放Workbook对象资源,否则带有数据的Workbook一直会常驻内存

    (1) 将行列对象写出到Excel

    List<String> row1 = CollUtil.newArrayList("aa", "bb", "cc", "dd");List<String> row2 = CollUtil.newArrayList("aa1", "bb1", "cc1", "dd1");List<String> row3 = CollUtil.newArrayList("aa2", "bb2", "cc2", "dd2");List<String> row4 = CollUtil.newArrayList("aa3", "bb3", "cc3", "dd3");List<String> row5 = CollUtil.newArrayList("aa4", "bb4", "cc4", "dd4");List<List<String>> rows = CollUtil.newArrayList(row1, row2, row3, row4, row5);//通过工具类创建writerExcelWriter writer = ExcelUtil.getWriter("d:/writeTest.xlsx");//通过构造方法创建writer//ExcelWriter writer = new ExcelWriter("d:/writeTest.xls");//跳过当前行,既第一行,非必须,在此演示用writer.passCurrentRow();//合并单元格后的标题行,使用默认标题样式writer.merge(row1.size() - 1, "测试标题");//一次性写出内容,强制输出标题writer.write(rows, true);//关闭writer,释放内存writer.close();

    (2)写出Map数据

    Map<String, Object> row1 = new LinkedHashMap<>();row1.put("姓名", "张三");row1.put("年龄", 23);row1.put("成绩", 88.32);row1.put("是否合格", true);row1.put("考试日期", DateUtil.date());Map<String, Object> row2 = new LinkedHashMap<>();row2.put("姓名", "李四");row2.put("年龄", 33);row2.put("成绩", 59.50);row2.put("是否合格", false);row2.put("考试日期", DateUtil.date());ArrayList<Map<String, Object>> rows = CollUtil.newArrayList(row1, row2);// 通过工具类创建writerExcelWriter writer = ExcelUtil.getWriter("d:/writeMapTest.xlsx");// 合并单元格后的标题行,使用默认标题样式writer.merge(row1.size() - 1, "一班成绩单");// 一次性写出内容,使用默认样式,强制输出标题writer.write(rows, true);// 关闭writer,释放内存writer.close();

    (3)写出Bean数据

    public class TestBean {    private String name;    private int age;    private double score;    private boolean isPass;    private Date examDate;    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public int getAge() {        return age;    }    public void setAge(int age) {        this.age = age;    }    public double getScore() {        return score;    }    public void setScore(double score) {        this.score = score;    }    public boolean isPass() {        return isPass;    }    public void setPass(boolean isPass) {        this.isPass = isPass;    }    public Date getExamDate() {        return examDate;    }    public void setExamDate(Date examDate) {        this.examDate = examDate;    }}TestBean bean1 = new TestBean();bean1.setName("张三");bean1.setAge(22);bean1.setPass(true);bean1.setScore(66.30);bean1.setExamDate(DateUtil.date());TestBean bean2 = new TestBean();bean2.setName("李四");bean2.setAge(28);bean2.setPass(false);bean2.setScore(38.50);bean2.setExamDate(DateUtil.date());List<TestBean> rows = CollUtil.newArrayList(bean1, bean2);// 通过工具类创建writerExcelWriter writer = ExcelUtil.getWriter("d:/writeBeanTest.xlsx");// 合并单元格后的标题行,使用默认标题样式writer.merge(4, "一班成绩单");// 一次性写出内容,使用默认样式,强制输出标题writer.write(rows, true);// 关闭writer,释放内存writer.close();

    (4)自定义Bean的key别名(排序标题)

    在写出Bean的时候,我们可以调用ExcelWriter对象的addHeaderAlias方法自定义Bean中key的别名,这样就可以写出自定义标题了

    // 通过工具类创建writerExcelWriter writer = ExcelUtil.getWriter("d:/writeBeanTest.xlsx");//自定义标题别名writer.addHeaderAlias("name", "姓名");writer.addHeaderAlias("age", "年龄");writer.addHeaderAlias("score", "分数");writer.addHeaderAlias("isPass", "是否通过");writer.addHeaderAlias("examDate", "考试时间");// 合并单元格后的标题行,使用默认标题样式writer.merge(4, "一班成绩单");// 一次性写出内容,使用默认样式,强制输出标题writer.write(rows, true);// 关闭writer,释放内存writer.close();

    java解析Excel使用hutool工具类

    hutool包,真是好用,方便,强烈推荐…

    https://hutool.cn/docs/index.html#/

    然后使用Excel的工具类,还需要引入poi-ooxml包版本的话,报错里面有

    自己确认一下就好了

     <!-- Https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml -->        <dependency>            <groupId>org.apache.poi</groupId>            <artifactId>poi-ooxml</artifactId>            <version>3.17</version>        </dependency>

    一行代码搞定:常用的就是read方法了.

    ExcelReader reader = ExcelUtil.getReader(FileUtil.file("C:\\Users\\stack\\Desktop\\hanke\\aaa.xlsx"));

    Hutool Java工具类库_ExcelUtil怎么使用

    到此,关于“Hutool Java工具类库_ExcelUtil怎么使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

    --结束END--

    本文标题: Hutool Java工具类库_ExcelUtil怎么使用

    本文链接: https://www.lsjlt.com/news/300792.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • C++ 生态系统中流行库和框架的贡献指南
      作为 c++++ 开发人员,通过遵循以下步骤即可为流行库和框架做出贡献:选择一个项目并熟悉其代码库。在 issue 跟踪器中寻找适合初学者的问题。创建一个新分支,实现修复并添加测试。提交...
      99+
      2024-05-15
      框架 c++ 流行库 git
    • C++ 生态系统中流行库和框架的社区支持情况
      c++++生态系统中流行库和框架的社区支持情况:boost:活跃的社区提供广泛的文档、教程和讨论区,确保持续的维护和更新。qt:庞大的社区提供丰富的文档、示例和论坛,积极参与开发和维护。...
      99+
      2024-05-15
      生态系统 社区支持 c++ overflow 标准库
    • c++中if elseif使用规则
      c++ 中 if-else if 语句的使用规则为:语法:if (条件1) { // 执行代码块 1} else if (条件 2) { // 执行代码块 2}// ...else ...
      99+
      2024-05-15
      c++
    • c++中的继承怎么写
      继承是一种允许类从现有类派生并访问其成员的强大机制。在 c++ 中,继承类型包括:单继承:一个子类从一个基类继承。多继承:一个子类从多个基类继承。层次继承:多个子类从同一个基类继承。多层...
      99+
      2024-05-15
      c++
    • c++中如何使用类和对象掌握目标
      在 c++ 中创建类和对象:使用 class 关键字定义类,包含数据成员和方法。使用对象名称和类名称创建对象。访问权限包括:公有、受保护和私有。数据成员是类的变量,每个对象拥有自己的副本...
      99+
      2024-05-15
      c++
    • c++中优先级是什么意思
      c++ 中的优先级规则:优先级高的操作符先执行,相同优先级的从左到右执行,括号可改变执行顺序。操作符优先级表包含从最高到最低的优先级列表,其中赋值运算符具有最低优先级。通过了解优先级,可...
      99+
      2024-05-15
      c++
    • c++中a+是什么意思
      c++ 中的 a+ 运算符表示自增运算符,用于将变量递增 1 并将结果存储在同一变量中。语法为 a++,用法包括循环和计数器。它可与后置递增运算符 ++a 交换使用,后者在表达式求值后递...
      99+
      2024-05-15
      c++
    • c++中a.b什么意思
      c++kquote>“a.b”表示对象“a”的成员“b”,用于访问对象成员,可用“对象名.成员名”的语法。它还可以用于访问嵌套成员,如“对象名.嵌套成员名.成员名”的语法。 c++...
      99+
      2024-05-15
      c++
    • C++ 并发编程库的优缺点
      c++++ 提供了多种并发编程库,满足不同场景下的需求。线程库 (std::thread) 易于使用但开销大;异步库 (std::async) 可异步执行任务,但 api 复杂;协程库 ...
      99+
      2024-05-15
      c++ 并发编程
    • 如何在 Golang 中备份数据库?
      在 golang 中备份数据库对于保护数据至关重要。可以使用标准库中的 database/sql 包,或第三方包如 github.com/go-sql-driver/mysql。具体步骤...
      99+
      2024-05-15
      golang 数据库备份 mysql git 标准库
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作