Apache POI

一、介绍

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

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

准备工作:

在pom文件中导入依赖---

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

二、操作方法

1、通过POI向Excel文件写入内容
复制代码
/**
     * 通过POI创建Excel文件并写入文件内容
     */
    private static void write() throws Exception {
//        在内存中创建一个Excel文件
        XSSFWorkbook excel = new XSSFWorkbook();
//        在Excel文件中创建一个Sheet页
        XSSFSheet sheet = excel.createSheet("info");
//        在Sheet页中创建行对象,rownum编号从0开始
        XSSFRow row = sheet.createRow(1);
//        创建单元格并且写入文件内容
        row.createCell(1).setCellValue("姓名");
        row.createCell(2).setCellValue("城市");

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

        row = sheet.createRow(3);
        row.createCell(1).setCellValue("李四");
        row.createCell(2).setCellValue("南京");

//        通过输出流将内存中的Excel文件写入到磁盘
        FileOutputStream out = new FileOutputStream(new File("F:\\info.xlsx"));
        excel.write(out);

//        关闭资源
        out.close();
        excel.close();
    }
2、 通过POI将Excel文件内容读出

其中 i的变量为1,也就是说我是从表第二行开始读的,如果你第一行有数据,就将i的变量改为0.

复制代码
    /**
     * 通过POI读取Excel文件中的内容
     *
     * @throws Exception
     */
    private static void read() throws Exception {
        FileInputStream in = new FileInputStream(new File("F:\\info.xlsx"));

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

//        获取sheet中最后一行的行号
        int lastRowNum = sheet.getLastRowNum();

        for (int i = 1; i <= lastRowNum; i++) {
//            获得某一行
            XSSFRow row = sheet.getRow(i);
//            获得单元格对象
            String cellValue1 = row.getCell(1).getStringCellValue();
            String cellValue2 = row.getCell(2).getStringCellValue();
            System.out.println(cellValue1 + " " + cellValue2);
        }

//        关闭资源
        in.close();
        excel.close();
    }
相关推荐
大模型玩家七七1 小时前
基于语义切分 vs 基于结构切分的实际差异
java·开发语言·数据库·安全·batch
寻星探路6 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
曹牧8 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
爬山算法9 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7259 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎9 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄9 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
忆~遂愿9 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能
小韩学长yyds10 小时前
Java序列化避坑指南:明确这4种场景,再也不盲目实现Serializable
java·序列化