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

发布于:2025-05-07 ⋅ 阅读:(13) ⋅ 点赞:(0)

目录

一、Apache POI 简介

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

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


一、Apache POI 简介

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

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

1.导入Maven坐标

<!-- 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文件,并写入数据

    /**
     * 通过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文件中的内容

    /**
     * 通过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文件,并生成输出流供客户端下载。

代码示例:

/**
 * 导出运营数据报表
 */
@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);
    }


}


网站公告

今日签到

点亮在社区的每一天
去签到