目录
一、前言
1、什么是Apache POI?
Apache POI 是一个处理Miscrosoft Office各种文件格式的开源项目。简单来说就是,我们可以使用 POI 在 Java 程序中对Miscrosoft Office各种文件进行读写操作。 一般情况下,POI 都是用于操作 Excel 文件。
2、它的应用场景
例如银行网银系统导出交易明细、各种业务系统导出Excel报表、批量导入业务数据等。
二、快速入门
Apache POI既可以将数据写入Excel文件,也可以读取Excel文件中的数据,接下来分别进行实现。
首先要使用Apache POI,先导入它的maven坐标
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.16</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.16</version>
</dependency>
1、写入操作
将数据写入到Excel文件当中。
public static void write() throws Exception {
// 在内存中创建一个Excel文件
XSSFWorkbook excel = new XSSFWorkbook();
// 在Excel文件中创建一个sheet页
XSSFSheet sheet = excel.createSheet("info1");
// 在sheet中创建行对象,row从0开始
XSSFRow row = sheet.createRow(0);
// 创建单元格并且写入文件内容
row.createCell(0).setCellValue("name");
row.createCell(1).setCellValue("age");
row.createCell(2).setCellValue("password");
row = sheet.createRow(1);
row.createCell(0).setCellValue("zhangsan");
row.createCell(1).setCellValue("29");
row.createCell(2).setCellValue("123456");
// 通过输出流将内存中的excel文件写入到磁盘当中
FileOutputStream out = new FileOutputStream("盘符名:\\***\\123.xlsx");
excel.write(out);
// 关闭资源
out.close();
excel.close();
}
此方法(write)的作用为通过POI创建Excel文件并且写入文件内容,启动一下,见效果:
打开来看看。
2、读取数据
将Excel文件当中的数据读取出来并输出。
public static void read() throws Exception {
// 读取磁盘上面已经存在的Excel文件
XSSFWorkbook excel = new XSSFWorkbook(new FileInputStream("盘符名:\\***\\123.xlsx"));
// 读取Excel文件里面的第一个sheet页
XSSFSheet sheet = excel.getSheetAt(0);
// 获取最后一行有数据的文件
int lastRowNum = sheet.getLastRowNum();
for (int i = 0; i <= lastRowNum; i++) {
// 获取某一行
XSSFRow row = sheet.getRow(i);
String cellValue1 = row.getCell(0).getStringCellValue();
String cellValue2 = row.getCell(1).getStringCellValue();
String cellValue3 = row.getCell(2).getStringCellValue();
System.out.println(cellValue1 + "\t" + cellValue2 + "\t" + cellValue3);
}
// 关闭资源
excel.close();
}
效果展示
项目实际效果
在某某系统里面,有个数据导出功能,点击之后将相关数据导出
前端路径为/export,控制层接收,将数据传到业务层,然后进行xxx操作,然后通过输出流将Excel文件下载到客户端浏览器,最后关闭资源,完成操作。