Apache POl

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

Apache POl 的应用场景:

  1. 银行网银系统导出交易明细
  2. 各种业务系统导出Excel报表
  3. 批量导入业务数据

使用POI需要导入下面2个坐标:

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
</dependency>

往表格存数据:

public class POITest {
    /*
    * 通过POI创建Excel文件并且写入文件内容
    * */
    @Test
    public void writeTest() throws IOException {
        //在内存中创建一个Excel文件
        XSSFWorkbook excel = new XSSFWorkbook();
        //在Excel文件中创建一个Sheet页
        XSSFSheet sheet = excel.createSheet("info");
        //在Sheet中创建行对象,rownum编号从0开始
        XSSFRow row = sheet.createRow(1); //1代表第2行
        row.createCell(1).setCellValue("姓名");//创建单元格写入内容
        row.createCell(2).setCellValue("城市");
        //创建一个新行
        row = sheet.createRow(2);//第3行
        row.createCell(1).setCellValue("张三");//创建单元格写入内容
        row.createCell(2).setCellValue("厦门");
 
        row = sheet.createRow(3);//第4行
        row.createCell(1).setCellValue("李四");//创建单元格写入内容
        row.createCell(2).setCellValue("南京");
        //上面写的都是在内存,现在想在磁盘看到
        FileOutputStream out = new FileOutputStream(new File("C://software/info.xlsx"));//设置文件
        excel.write(out);//写入到文件
        //关闭资源
        out.close();
        excel.close();
 
    }
}

读取excel中的数据:

@Test
public void readTest() throws IOException{
    FileInputStream in = new FileInputStream(new File("C://software/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();
 
}

代码解析:

public void export(HttpServletResponse response){
        reportService.exportBusinessData(response);
    }

其中**HttpServletResponse** 是 Java Servlet API 中的一个接口,用于在服务器端向客户端发送 HTTP 响应。它提供了一系列方法,用于设置和控制响应的内容、状态码、头部信息等。

具体来说,HttpServletResponse 接口允许开发者在 Servlet 中生成 HTTP 响应,并将其发送到客户端。通过该接口,开发者可以:

  1. 设置响应的状态码和状态消息(例如:200 OK、404 Not Found)。
  2. 添加响应头部信息(例如:Content-Type、Cache-Control)。
  3. 获取输出流,以便向客户端发送数据。
  4. 设置响应的字符编码和内容类型。
  5. 重定向请求到其他 URL。
  6. 向响应中添加 Cookie。在上面的代码中起到的是第三个功能。

使用 HttpServletResponse 接口,开发者可以灵活地控制和定制服务器端向客户端发送的 HTTP 响应,以实现各种需求,如返回网页、文件下载、JSON 数据等。

相关推荐
mqiqe4 小时前
Apache Tika 详解
apache
鸠摩智首席音效师18 小时前
如何解决 Apache Shutdown Unexpectedly 错误 ?
apache
大鳥1 天前
Apache Hive 聚合函数与 OVER 窗口函数:从基础到高级应用
hive·hadoop·apache
neter.asia2 天前
小程序获取微信运动步数
微信·小程序·apache
m0_548514772 天前
Centos7搭建PHP项目,环境(Apache+PHP7.4+Mysql5.7)
开发语言·php·apache
m0_748234522 天前
Apache Tomcat文件包含漏洞复现(详细教程)
java·tomcat·apache
代立冬2 天前
流行的开源高性能数据同步工具 - Apache SeaTunnel 整体架构运行原理
apache·datax·开源数据集成工具·超高性能数据集成工具·异构数据同步工具·比datax更好的工具
一條狗2 天前
20250120 深入了解 Apache Flink 的 Checkpointing
大数据·flink·apache
怎么昵称都被占用啊3 天前
【Linux系统环境中使用二进制包安装Apache】
linux·运维·apache
熊文豪3 天前
使用 Java 和 FreeMarker 实现自动生成供货清单,动态生成 Word 文档,简化文档处理流程。
java·apache·freemarker