入门案例
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>
2.2.1 将数据写入Excel文件
1). 代码开发
package com.sky;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.junit.jupiter.api.Test;
import java.io.FileOutputStream;
public class POITest {
/**
* 基于POI向Excel文件写入数据
*/
@Test
public void write() throws Exception {
//在内存中创建一个Excel文件对象
XSSFWorkbook excel = new XSSFWorkbook();
//创建Sheet页
XSSFSheet sheet = excel.createSheet("Sheet1");
//在Sheet页中创建行,0表示第1行
XSSFRow row = sheet.createRow(0);
//创建单元格并在单元格中设置值,单元格编号也是从0开始,1表示第2个单元格
row.createCell(1).setCellValue("姓名");
//通过输出流将内存中的Excel文件写入到磁盘上
FileOutputStream out = new FileOutputStream("D:\\itcast.xlsx");
excel.write(out);
//关闭资源
out.flush();
out.close();
excel.close();
}
}
2). 实现效果
在D盘中生成itcast.xlsx文件,创建名称为itcast的Sheet1页,同时将内容成功写入。
2.2.2 读取Excel文件中的数据
1). 代码开发
package com.sky;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.junit.jupiter.api.Test;
import java.io.FileInputStream;
import java.io.FileOutputStream;
public class POITest {
/**
* 基于POI读取Excel文件的数据
*/
@Test
public void read() throws Exception {
FileInputStream in = new FileInputStream("D:\\itcast.xlsx");
//通过输入流读取指定的Excel文件
XSSFWorkbook excel = new XSSFWorkbook(in);
//获取Excel文件的第1个Sheet页
XSSFSheet sheet = excel.getSheetAt(0);
//获取Sheet页中的第1行
XSSFRow row = sheet.getRow(0);
//获取行的第2个单元格
XSSFCell cell = row.getCell(1);
String value = cell.getStringCellValue();
System.out.println(value);
//关闭资源
in.close();
excel.close();
}
}