POI支持xls和xlsx文件的操作
使用POI首先要导入依赖
<!--POI-->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml-schemas</artifactId>
<version>4.0.1</version>
</dependency>
1. 随便Excel文件中填充个数据
public class PoiTest {
@test
public void testWriteByPoi() throws IOException {
//1.在内存中创建Excel文件
Workbook wb = new XSSFWorkbook();
//2.创建工作表
Sheet sheet1 = wb.createSheet(); //创建一个工作表(默认第一个工作表名称是Sheet0)
wb.createSheet("这是啥呀"); //创建时也可以指定工作表的名称
//3.创建工作表中的行对象
Row row_0 = sheet.createRow(0);//对应文件中的第一行
//4.创建工作表中行中的列对象
Cell cell_0_0 = row_0.createCell(0); //对应第一列,通过行和列确定具体是哪个单元格
//5.在单元格中写数据
cell_0_0 .setCellValue("测试一下单元格");//将数据写到了第一行第一列的位置上。
//6.创建一个文件对象,作为盛放excel文件内容的输出文件
File f = new File("test.xlsx");
//7.输出时通过流的形式对外输出,包装对应的目标文件
OutputStream os = new FileOutputStream(f);
//8.将内存中的workbook数据写入到流中
wb.write(os);
wb.close();
os.close();
}
}
2. 合并单元格,设置单元格的样式,写入一个标题
@Test
public void testProjectPoi() throws IOException {
//1.获取到对应的Excel文件,工作簿文件
Workbook wb = new XSSFWorkbook();
//2.创建工作表
Sheet s = wb.createSheet("题目数据文件");
//3.合并行 (MergedRegion:合并区域)
s.addMergedRegion(new CellRangeAddress(1,1,1,12)); //第一行,最后一行,第一列,最后一列(合并1行1列至1行12列)
Row row_1 = s.createRow(1);
Cell cell_1_1 = row_1.createCell(1);//第一行第一列
cell_1_1.setCellValue("在线试题导出信息"); //写入数据
//4.创建一个样式
CellStyle cs_title = wb.createCellStyle();
cs_title.setAlignment(HorizontalAlignment.CENTER); //对齐方式(Alignment):为水平居中(HorizontalAlignment.CENTER)
cs_title.setVerticalAlignment(VerticalAlignment.CENTER);//垂直居中
//5.为大单元格添加样式
cell_1_1.setCellStyle(cs_title);//
//6.创建一个文件对象,作为excel文件内容的输出文件
File f = new File("test.xlsx");
//7.输出时通过流的形式对外输出,包装对应的目标文件
OutputStream os = new FileOutputStream(f);
//8.将内存中的workbook数据写入到流中
wb.write(os);
wb.close();
os.close();
}
3. 循环录入多个数据到一行,例如制作标题。
@Test
public void testProjectPoi() throws IOException {
//1.获取到对应的Excel文件,工作簿文件
Workbook wb = new XSSFWorkbook();
//2.创建工作表
Sheet s = wb.createSheet("题目数据文件");
//3.制作表头
String[] fields = {"题目ID","所属公司ID","所属目录ID","题目简介","题干描述",
"题干配图","题目分析","题目类型","题目难度","是否经典题","题目状态","审核状态"};
Row row_2 = s.createRow(1);//第二行
for (int i = 0; i < fields.length; i++) {
Cell cell_2_temp = row_2.createCell(1 + i); //++
cell_2_temp.setCellValue(fields[i]); //++
CellStyle cs_field = wb.createCellStyle();
cs_field.setAlignment(HorizontalAlignment.CENTER);
cell_2_temp.setCellStyle(cs_field);
}
//创建一个文件对象,作为excel文件内容的输出文件
File f = new File("test.xlsx");
//输出时通过流的形式对外输出,包装对应的目标文件
OutputStream os = new FileOutputStream(f);
//将内存中的workbook数据写入到流中
wb.write(os);
wb.close();
os.close();
}