Apache POI的Workbook读取和写入excel文件

17 篇文章 0 订阅

maven依赖

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

编码

    @Test
    public void formatLogFile() {
        // 需要读取的文件
        String filePath = "/Users/lizz/Documents/readDatas.xlsx";
        File file = new File(filePath);
        Workbook workbook = null;
        try {
            workbook = WorkbookFactory.create(new FileInputStream(file));
        } catch (IOException e) {
            e.printStackTrace();
        }
        // 获取文件的第几个Sheet,从0开始
        Sheet sheetAt = workbook.getSheetAt(0);
        int rowNum = 0;
        int cellNum = 0;
        //临时存储数据,这里可以根据自己的需要使用不同的存储类型
        List<Map<String, String>> maps = new ArrayList<>(4096);

        //循环读取数据,直到位空时
        // 这里也可以固定读取行数
        while (true) {
            // 读取第n行数据
            Row row = sheetAt.getRow(rowNum++);
            if (row == null) {
                break;
            }

            // 循环读取每行中每一列数据,值到有空值位置
            // 这里也可以固定读取列数,防止某列位空就不读后面的字段了
            // 比如当第一行位字段名时,可以使用字段名个数作为列的个数
            Map map = new HashMap();
            cellNum = 0;
            while (true) {
                // 获取某一列对象
                Cell cell = row.getCell(cellNum++);
                if (cell == null) {
                    break;
                }
                //  获取该列哪的数据,可以根据单元格类型获取数据
                //  如:CellType.BOOLEAN/CellType.NUMERIC等
                if (cell.getCellType() == CellType.STRING) {
                    String value = cell.getRichStringCellValue().getString();
                    map.put(cellNum, value);
                }
            }
            maps.add(map);
        }
        // 保存写入文件
        saveFile(maps);
    }

    private void saveFile(List<Map<String, String>> maps) {
        HSSFWorkbook wb = new HSSFWorkbook();
        // 写入execl文件的Sheet名称
        HSSFSheet sheet = wb.createSheet("sheetLizz");
        int outRowNum = 0;
        // 单元格样式,创建过多会导致内存溢出。
        // 根据自己需要设计
        HSSFCellStyle style = wb.createCellStyle();
        HSSFFont font = wb.createFont();
        style.setFont(font);
        // 写入数据
        for (Map<String, String> map : maps) {
            // 在第几行数据
            HSSFRow row = sheet.createRow(outRowNum++);
            // 在第几列写入数据
            HSSFCell cell1 = row.createCell(0);
            // 写入数据类型
            // HSSFRichTextString为文本类型
            HSSFRichTextString richString = new HSSFRichTextString(map.get(0));
            // 设置单元格值
            cell1.setCellValue(richString);
            // 设置单元格样式
            cell1.setCellStyle(style);
            HSSFCell cell2 = row.createCell(1);
            HSSFRichTextString richString1 = new HSSFRichTextString(map.get(1));
            cell2.setCellValue(richString1);
            cell2.setCellStyle(style);
            HSSFCell cell3 = row.createCell(2);
            HSSFRichTextString richString2 = new HSSFRichTextString(map.get(2));
            cell3.setCellValue(richString2);
            cell3.setCellStyle(style);
        }
        //输出到指定文件,不存在自动创建
        try {
            FileOutputStream output = new FileOutputStream("/Users/lizz/Documents/writeDatas.xlsx");
            wb.write(output);
            output.flush();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
POIApache软件基金会推出的一款用于操作Microsoft Office格式文件的Java库。它可以帮助我们读取、创建和修改Excel文件。 在POI中,Sheet页可以理解为Excel文件中的工作表,而一个Sheet页可以包含多个表头。表头通常用于标识和描述该Sheet页中数据的每一列。 在创建一个带有多个表头的Sheet页时,首先需要创建一个Sheet对象,然后通过调用该对象的createRow方法创建行对象,最后在行对象中使用createCell方法创建单元格对象并设置单元格的值。 将多个表头写入到Sheet页中的步骤如下: 1. 创建Sheet对象:使用Workbook对象的createSheet方法创建一个Sheet对象,可指定Sheet页的名称和索引。 2. 创建行对象:使用Sheet对象的createRow方法创建一个行对象,表示Sheet页中的一行数据。 3. 创建单元格对象:使用行对象的createCell方法创建多个单元格对象。 4. 设置表头值:使用单元格对象的setCellValue方法将表头的值设置到对应的单元格中。 5. 设置表头样式:使用POI提供的样式类和字体类,可以设置表头的样式,包括字体、颜色、边框等。 6. 重复步骤2-5,直到将所有表头的值设置完成。 7. 将Sheet页写入Excel文件中:使用Workbook对象的write方法将Sheet页写入Excel文件中。 总的来说,POI可以很方便地操作Excel文件,在创建Sheet页时,我们可以根据需求来设置多个表头,通过调用POI提供的方法将表头值写入到对应的单元格中。这样就可以实现一个Sheet页中包含多个表头的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lizz666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值