Apache POl Excel

目录

介绍

[Apache POl的应用场景:](#Apache POl的应用场景:)

入门使用

通过POI创建Excel文件并且写入文件内容

通过POI读取Excel文件中的内容


介绍

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

一般情况下,POI都是用于操作Excel文件。

Apache POl的应用场景:

  • 银行网银系统导出交易明细
  • 各种业务系统导出Exceli报表
  • 批量导入业务数据

入门使用

Apache POl的maven坐标:

XML 复制代码
<!-- poi -->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
</dependency>

通过POI创建Excel文件并且写入文件内容

java 复制代码
public static void write() throws Exception {
        // 在内存中创建一个Excel文件
        XSSFWorkbook excel = new XSSFWorkbook();
        // 在Excel文件中常见一个Sheet页
        XSSFSheet sheet = excel.createSheet("hello");
        // 在Sheet中创建行对象,rownum编号从0开始
        XSSFRow row = sheet.createRow(0);
        // 创建单元格
        XSSFCell cell = row.createCell(0);
        // 在单元格内写入文件内容
        cell.setCellValue("姓名");
        cell = row.createCell(1);
        cell.setCellValue("城市");

        // 创建一个新行
        row = sheet.createRow(1);
        row.createCell(0).setCellValue("张三");
        row.createCell(1).setCellValue("北京");

        row = sheet.createRow(2);
        row.createCell(0).setCellValue("李四");
        row.createCell(1).setCellValue("天津");

        // 通过输出流将内存中的Excel文件写入磁盘

        FileOutputStream out = new FileOutputStream(new File("D:\\hello.xlsx"));
        excel.write(out);

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

效果展示

通过POI读取Excel文件中的内容

java 复制代码
public static void read() throws Exception {
        InputStream in = new FileInputStream(new File("D:\\hello.xlsx"));

        // 读取磁盘上已经存在的Excel文件
        XSSFWorkbook excel = new XSSFWorkbook(in);
        // 读取Excel文件中的第一个Sheet页
        XSSFSheet sheet = excel.getSheetAt(0);

        // 读取Sheet中最后一行的行号
        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();
            System.out.println(cellValue1 + " " + cellValue2);
        }

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

    }

结果展示

相关推荐
gadiaola几秒前
【JavaSE面试篇】Java集合部分高频八股汇总
java·面试
艾迪的技术之路23 分钟前
redisson使用lock导致死锁问题
java·后端·面试
今天背单词了吗98041 分钟前
算法学习笔记:8.Bellman-Ford 算法——从原理到实战,涵盖 LeetCode 与考研 408 例题
java·开发语言·后端·算法·最短路径问题
天天摸鱼的java工程师44 分钟前
使用 Spring Boot 整合高德地图实现路线规划功能
java·后端
东阳马生架构1 小时前
订单初版—2.生单链路中的技术问题说明文档
java
咖啡啡不加糖1 小时前
暴力破解漏洞与命令执行漏洞
java·后端·web安全
风象南1 小时前
SpringBoot敏感配置项加密与解密实战
java·spring boot·后端
DKPT1 小时前
Java享元模式实现方式与应用场景分析
java·笔记·学习·设计模式·享元模式
Percep_gan2 小时前
idea的使用小技巧,个人向
java·ide·intellij-idea