快速上手Apache POI

哈喽~大家好,这篇我们来看看快速上手Apache POI。

🥇个人主页:个人主页​​​​​

🥈 系列专栏:【日常学习上的分享】

🥉与这篇相关的文章:

|--------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Redis快速入门及在Java中使用Redis | Redis快速入门及在Java中使用Redis_程序猿追的博客-CSDN博客 |
| 为什么不推荐使用Lombok?@Data不香吗? | 为什么不推荐使用Lombok?@Data不香吗?-CSDN博客 |
| Mybatis报错: Parameter 'XXX' not found. Available parameters are [arg1, arg0, param1, param2]解决方案及问题原因 | Mybatis报错: Parameter 'XXX' not found. Available parameters are [arg1, arg0, param1, param2]解决方案及问题原因-CSDN博客 |

目录

一、前言

[1、什么是Apache POI?](#1、什么是Apache POI?)

2、它的应用场景

二、快速入门

1、写入操作

2、读取数据


一、前言

1、什么是Apache POI?

Apache POI 是一个处理Miscrosoft Office各种文件格式的开源项目。简单来说就是,我们可以使用 POI 在 Java 程序中对Miscrosoft Office各种文件进行读写操作。 一般情况下,POI 都是用于操作 Excel 文件。

2、它的应用场景

例如银行网银系统导出交易明细、各种业务系统导出Excel报表、批量导入业务数据等。

二、快速入门

Apache POI既可以将数据写入Excel文件,也可以读取Excel文件中的数据,接下来分别进行实现。

首先要使用Apache POI,先导入它的maven坐标

java 复制代码
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>3.16</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>3.16</version>
</dependency>

1、写入操作

将数据写入到Excel文件当中。

java 复制代码
    public static void write() throws Exception {

        // 在内存中创建一个Excel文件
        XSSFWorkbook excel = new XSSFWorkbook();
        // 在Excel文件中创建一个sheet页
        XSSFSheet sheet = excel.createSheet("info1");
        // 在sheet中创建行对象,row从0开始
        XSSFRow row = sheet.createRow(0);
        // 创建单元格并且写入文件内容
        row.createCell(0).setCellValue("name");
        row.createCell(1).setCellValue("age");
        row.createCell(2).setCellValue("password");

        row = sheet.createRow(1);

        row.createCell(0).setCellValue("zhangsan");
        row.createCell(1).setCellValue("29");
        row.createCell(2).setCellValue("123456");

        // 通过输出流将内存中的excel文件写入到磁盘当中
        FileOutputStream out = new FileOutputStream("盘符名:\\***\\123.xlsx");
        excel.write(out);

        // 关闭资源
        out.close();
        excel.close();

    }

扩:

POI提供了HSSF、XSSF以及SXSSF三种方式操作Excel。

HSSF:Excel97-2003版本,扩展名为.xls。一个sheet最大行数65536,最大列数256。

XSSF:Excel2007版本开始,扩展名为.xlsx。一个sheet最大行数1048576,最大列数16384。

SXSSF:是在XSSF基础上,POI3.8版本开始提供的支持低内存占用的操作方式,扩展名为.xlsx。

createSheet在Excel文件中创建一个sheet页,createRow在sheet中创建行对象,row从0开始。

createCell创建单元格,setCellValue写入文件内容。

此方法(write)的作用为通过POI创建Excel文件并且写入文件内容,启动一下,见效果:

打开来看看。

2、读取数据

将Excel文件当中的数据读取出来并输出。

java 复制代码
    public static void read() throws Exception {

        // 读取磁盘上面已经存在的Excel文件
        XSSFWorkbook excel = new XSSFWorkbook(new FileInputStream("盘符名:\\***\\123.xlsx"));

        // 读取Excel文件里面的第一个sheet页
        XSSFSheet sheet = excel.getSheetAt(0);

        // 获取最后一行有数据的文件
        int lastRowNum = sheet.getLastRowNum();

        for (int i = 0; i <= lastRowNum; i++) {
            // 获取某一行
            XSSFRow row = sheet.getRow(i);
            String cellValue1 = row.getCell(0).getStringCellValue();
            String cellValue2 = row.getCell(1).getStringCellValue();
            String cellValue3 = row.getCell(2).getStringCellValue();

            System.out.println(cellValue1 + "\t" + cellValue2 + "\t" + cellValue3);
        }

        // 关闭资源
        excel.close();

    }

效果展示

项目实际效果

在某某系统里面,有个数据导出功能,点击之后将相关数据导出

前端路径为/export,控制层接收,将数据传到业务层,然后进行xxx操作,然后通过输出流将Excel文件下载到客户端浏览器,最后关闭资源,完成操作。

不积跬步无以至千里,趁年轻,使劲拼,给未来的自己一个交代!向着明天更好的自己前进吧!

相关推荐
tsyjjOvO几秒前
SpringMVC 从入门到精通(续)
java·后端·spring
Binary-Jeff几秒前
MySQL MVCC 原理解析:Undo Log、ReadView 与版本可见性机制
java·数据库·后端·mysql·spring
于先生吖5 分钟前
基于 Java 开发短剧系统:完整架构与核心功能实现
java·开发语言·架构
专注_每天进步一点点5 分钟前
mysql-connector-j(8.0 及以上版本,包括你使用的 8.3.0)并非采用 GPL 许可证,因此你在项目中引入该依赖时,不需要遵循 GPL 的开源要求(比如开源你的整个项目)
数据库·mysql·apache
badhope6 分钟前
GitHub超有用项目推荐:skill仓库--用技能树打造AI超频引擎
java·开发语言·前端·人工智能·python·重构·github
一只鹿鹿鹿7 分钟前
网络安全风险评估报告如何写?(Word文件)
java·大数据·spring boot·安全·web安全·小程序
逆境不可逃8 分钟前
【后端新手谈 04】Spring 依赖注入所有方式 + 构造器注入成官方推荐的原因
java·开发语言·spring boot·后端·算法·spring·注入方式
Anastasiozzzz9 分钟前
深度解析 Java 单例模式
java·开发语言
不爱学英文的码字机器11 分钟前
Apache RocketMQ+cpolar 让消息服务全网可达
apache·rocketmq
NGC_661112 分钟前
G1收集器
java·开发语言·jvm