POI 之生成数据到 Excel

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值