Apache POI实现Excel的基本写入、导出操作

目录

[一、Apache POI 简介](#一、Apache POI 简介)

二、入门案例(写入导出)

三、实际开发过程中的导出操作------(将文件下载至客户端浏览器中)


一、Apache POI 简介

Apache POI(Poor Obfuscation Implementation)是 Apache 软件基金会的开源项目,提供 Java 操作 Microsoft Office 格式文件(如 Excel、Word、PowerPoint 等)的 API 库。

二、入门案例(写入导出)

1.导入Maven坐标

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

2.创建excel文件,并写入数据

java 复制代码
    /**
     * 通过POI创建Excel文件并写入数据
     */
    public static void write() throws IOException {
        // 在内存中创建一个新的Excel文件
        XSSFWorkbook excel = new XSSFWorkbook();
        // 创建一个新的sheet(sheet名为"info")
        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("D:\\info.xlsx");
        excel.write(out);
​
        // 关闭资源
        out.close();
        excel.close();
    }

效果图:

3.读取excel文件中的内容

java 复制代码
    /**
     * 通过POI读取Excel文件中的数据
     */
    public static void read() throws IOException {
        // 创建输入流
        FileInputStream in = new FileInputStream("D:\\info.xlsx");
        // 通过输入流读取Excel文件
        XSSFWorkbook workbook = new XSSFWorkbook(in);
        // 获取第一个sheet
        XSSFSheet sheet = workbook.getSheetAt(0);
​
        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();
        workbook.close();
    }

效果图:

三、实际开发过程中的导出操作------(将文件下载至客户端浏览器中)

1.准备好模板excel文件(调格式会比较麻烦,因此直接准备好)放到resources下的template文件夹下。

2.查询数据,将数据写入至excel文件,并生成输出流供客户端下载。

代码示例:

java 复制代码
/**
 * 导出运营数据报表
 */
@Override
public void exportBusinessData(HttpServletResponse response) {
    //1.查询数据库,获取营业数据---查询最近30天的运营数据
    LocalDate begin = LocalDate.now().minusDays(30);
    LocalDate end = LocalDate.now().minusDays(1);

    //查询概览数据
    BusinessDataVO businessDataVO = workspaceService.getBusinessData(LocalDateTime.of(begin, LocalTime.MIN), LocalDateTime.of(end, LocalTime.MAX));

    //2.通过POI将数据写入Excel文件
    InputStream in = this.getClass().getClassLoader().getResourceAsStream("template/运营数据报表模板.xlsx");

    try {
        //基于模板文件创建一个新的Excel文件
        XSSFWorkbook excel = new XSSFWorkbook(in);
        //获取表格文件的Sheet标签页
        XSSFSheet sheet1 = excel.getSheet("Sheet1");
        //填充数据--时间
        sheet1.getRow(1).getCell(1).setCellValue("时间:"+ begin + "至" + end);

        //获得第四行
        XSSFRow row = sheet1.getRow(3);
        row.getCell(2).setCellValue(businessDataVO.getTurnover());
        row.getCell(4).setCellValue(businessDataVO.getOrderCompletionRate());
        row.getCell(6).setCellValue(businessDataVO.getNewUsers());

        //获得第五行
        row = sheet1.getRow(4);
        row.getCell(2).setCellValue(businessDataVO.getValidOrderCount());
        row.getCell(4).setCellValue(businessDataVO.getUnitPrice());

        //填充明细数据
        for(int i=0;i<30;i++){
            LocalDate date = begin.plusDays(i);
            //查询某一天的营业数据
            businessDataVO = workspaceService.getBusinessData(LocalDateTime.of(date, LocalTime.MIN), LocalDateTime.of(date, LocalTime.MAX));

            //获得某一行
            row = sheet1.getRow(i+7);
            row.getCell(1).setCellValue(date.toString());
            row.getCell(2).setCellValue(businessDataVO.getTurnover());
            row.getCell(3).setCellValue(businessDataVO.getValidOrderCount());
            row.getCell(4).setCellValue(businessDataVO.getOrderCompletionRate());
            row.getCell(5).setCellValue(businessDataVO.getUnitPrice());
            row.getCell(6).setCellValue(businessDataVO.getNewUsers());

        }


        //3.通过输出流将Excel文件下载到客户端浏览器
        ServletOutputStream out= response.getOutputStream();
        excel.write(out);

        //关闭资源
        out.close();
        excel.close();
        in.close();
    } catch (IOException e) {
        throw new RuntimeException(e);
    }


}
相关推荐
hzj644 分钟前
GateWay使用
java·spring·gateway
苹果酱05674 小时前
【Azure Redis】Redis导入备份文件(RDB)失败的原因
java·vue.js·spring boot·mysql·课程设计
每次的天空4 小时前
Android第六次面试总结之Java设计模式(二)
android·java·面试
JAVA百练成神5 小时前
Java引用RabbitMQ快速入门
java·rabbitmq·java-rabbitmq
元亓亓亓5 小时前
Java后端开发day42--IO流(二)--字符集&字符流
java·开发语言
一刀到底2116 小时前
idea内存过低 设置 Maximum Heap Size 终极解决方案
java·ide·intellij-idea
振鹏Dong7 小时前
Java基础问题——八股盛宴 | 3w字分享
java
JH30737 小时前
【SpringBoot】SpringBoot中使用AOP实现日志记录功能
java·spring boot·后端
学java的cc7 小时前
Spring AI快速入门
java·大数据·spring
豆沙沙包?7 小时前
2025年- H17-Lc125-73.矩阵置零(矩阵)---java版
java·线性代数·矩阵