使用 Apache POI 更新/覆盖 特定的单元格

使用 Apache POI 更新特定的单元格

  • [一. 需求](#一. 需求)
  • [二. 实现](#二. 实现)
  • [三. 效果](#三. 效果)

一. 需求

将以下表中第4行,第4列的单元格由"张宇"更新为"汤家凤",并将更行后的结果写入新的Excel文件中;

二. 实现

使用Apache POI,可以精确定位到需要更改的单元格!高定制化的场景有时可能不适合用easyExcel;

步骤:

  • 由 file 依次 获取 workbook、sheet、row、cell;
  • 更新 cell;
  • 关闭 输入流,用新文件的path创建输出流;
  • 将更改后的 workbook 通过输出流 写入 新文件;
  • 关闭 workbook和输出流。
java 复制代码
import org.apache.poi.xssf.usermodel.*;
import org.junit.Test;
import java.io.*;

public class poiTest {
    @Test
    public void update() throws Exception{
        String sourceFile = "C:\\Users\\liziq\\Desktop\\student.xlsx"; // 原文件
        String newFile = "C:\\Users\\liziq\\Desktop\\student-new.xlsx"; // 更新后的新文件
        // 创建输入流
        FileInputStream fileInputStream = new FileInputStream(sourceFile);
        // 获取 workbook
        XSSFWorkbook wb = new XSSFWorkbook(fileInputStream);
        // 获取 sheet
        XSSFSheet sheet = wb.getSheetAt(0);
        // 获取单元格(index是从0开始)
        XSSFRow row = sheet.getRow(3);
        XSSFCell cell = row.getCell(3);
        // 更新单元格
        cell.setCellValue("汤家凤");
        // 关闭输入流
        fileInputStream.close();
        // 创建输出流
        FileOutputStream fileOutputStream=new FileOutputStream(newFile);
        // 将 workbook 写入 newFile
        wb.write(fileOutputStream);
        // 关闭workbook和输出流
        wb.close();
        fileOutputStream.close();
    }
}

三. 效果

生成"student-new.xlsx",教高数的变成了"汤家凤"!

参考:

https://blog.csdn.net/zouxiongqqq/article/details/78478298

相关推荐
云边有个稻草人12 小时前
大数据时代时序数据库选型深度指南:Apache IoTDB的技术内核与场景落地
大数据·apache·时序数据库·apache iotdb
一个天蝎座 白勺 程序猿1 天前
Apache IoTDB(14):IoTDB结果集排序与查询对齐模式——ORDER BY与ALIGN BY DEVICE使用
大数据·ai·apache·时序数据库·iotdb
一个天蝎座 白勺 程序猿1 天前
Apache IoTDB(9):数据库操作——数据写入从CLI到集群部署的六种实战
数据库·apache·时序数据库·iotdb
x***r1511 天前
Xampp集成环境包安装步骤详解(附Apache、MySQL启动与本地网站搭建)
数据库·mysql·apache
SelectDB技术团队2 天前
日志成本降低 83%:云上 Elasticsearch 和 SelectDB 的基准测试及成本分析
数据库·apache
正在走向自律2 天前
时序数据库选型指南:聚焦Apache IoTDB的核心优势与应用实践
apache·时序数据库·iotdb
Light602 天前
心智有效性测试小程序 V1.0 产品白皮书——心智结构量化与系统稳定性评估平台
小程序·apache
SelectDB技术团队2 天前
Apache Doris 4.0.3 版本正式发布
apache·mybatis
SelectDB2 天前
Apache Doris 4.0.3 版本正式发布
前端·apache
SelectDB2 天前
日志成本降低 83%:云上 Elasticsearch 和 SelectDB 的基准测试及成本分析
数据库·elasticsearch·apache