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);
    }


}
相关推荐
java叶新东老师4 分钟前
idea提交时忽略.class、.iml文件和文件夹或目录的方法
java·开发语言
飞翔的佩奇10 分钟前
Java项目:基于SSM框架实现的社区团购管理系统【ssm+B/S架构+源码+数据库+毕业论文+答辩PPT+远程部署】
java·数据库·vue.js·毕业设计·mybatis·答辩ppt·社区团购
TDengine (老段)23 分钟前
TDengine 转化函数 TO_TIMESTAMP 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
Warren9827 分钟前
Java Collections工具类
java·开发语言·笔记·python·学习·oracle·硬件工程
java叶新东老师43 分钟前
CMakelists.txt 实现多级目录编译
java·服务器·数据库
_风不会停息1 小时前
JDK1.8升级 JDK21 实践踩坑
java
封奚泽优1 小时前
使用Python绘制金融数据可视化工具
python·信息可视化·excel·pandas·pyplot·qtwidgets·qtcore
SimonKing1 小时前
一文搞定:SpringBoot集成语音识别模型FunASR
java·人工智能·后端
EumenidesJ1 小时前
Java常用日志框架介绍
java·log4j·logback·slf4j
lang201509281 小时前
Apache Ignite 的 JDBC Client Driver(JDBC 客户端驱动)
apache·ignite