POI Excel 在已有的Excel模板上写入 不改变格式 合并单元格的也可以

POI Excel 在已有的Excel模板上写入 不改变格式 合并单元格的也可以

使用的poi的相关jar包一定版本一定要相同,maven所使用jar包,没有使用maven的话,就用poi-3.9.jar和poi-ooxml-3.9.jar(这个主要是用于Excel2007以后的版本)两个jar包就行。

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>3.9</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>3.9</version>
</dependency>
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
public static void main(String[] args) throws IOException{
    //excle 2007
    String importFilePath= "E:/1.xls";//读取
    String exportFilePath= "D:/2.xls";//输出
    //excel模板路径
    File fi = new File(importFilePath);
    POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream(fi));
    //读取excel模板
    HSSFWorkbook wb = new HSSFWorkbook(fs);
    //读取了模板内所有sheet内容
    HSSFSheet sheet = wb.getSheetAt(0);
    //如果这行没有了,整个公式都不会有自动计算的效果的
    sheet.setForceFormulaRecalculation(true);
    //在相应的单元格进行赋值
    HSSFCell cell = sheet.getRow(0).getCell(0);//1行 A列
    cell.setCellValue(1);
    HSSFCell cell2 = sheet.getRow(26).getCell(4);//25行 E列
    cell2.setCellValue("中文");
    //修改模板内容导出新模板
    FileOutputStream out = new FileOutputStream(exportFilePath);
    wb.write(out);//输出流
    out.close();//关闭流
}
  1. 重要的事情说一遍,先行后列,从下坐标0开始数,不是从1开始。合并单元格的以最前面的格子为坐标。
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值