java 追加excel_java 如何往已经存在的excel表格里面追加数据的方法

本文介绍如何使用Java的Apache POI库向已存在的Excel文件追加数据。通过创建FileInputStream和FileOutputStream,以及使用HSSFWorkbook和HSSFSheet接口,可以在指定的工作表中定位并追加新的数据行。
摘要由CSDN通过智能技术生成

第一步、导入jar包,两个

第二步、编写程序

package cn.com.com;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;

import org.apache.poi.hssf.usermodel.HSSFRow;

import org.apache.poi.hssf.usermodel.HSSFSheet;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import org.apache.poi.poifs.filesystem.POIFSFileSystem;

public class Excel {

/*

* author:命运的信徒

* date:2019-07-31

* arm:通过java程序往excel里面续写数据

*/

public static void main(String[] args) {

String url="C:/Users/Administrator/Desktop/img/1.xls";

FileInputStream fs;

try {

fs = new FileInputStream(url);

POIFSFileSystem ps=new POIFSFileSystem(fs); //使用POI提供的方法得到excel的信息

HSSFWorkbook wb=new HSSFWorkbook(ps);

HSSFSheet sheet=wb.getSheetAt(0); //获取到工作表,因为一个excel可能有多个工作表

HSSFRow row=sheet.getRow(0);

int hang=0;

if("".equals(row)||row==null){

hang=0;

}else{

hang=sheet.getLastRowNum();

hang=hang+1;

}

//分别得到最后一行的行号,和一条记录的最后一个单元格

FileOutputStream out=new FileOutputStream(url); //向d://test.xls中写数据

row=sheet.createRow((short)(hang)); //在现有行号后追加数据

row.createCell(0).setCellValue("安徽"); //设置第一个(从0开始)单元格的数据

row.createCell(1).setCellValue("安庆"); //设置第二个(从0开始)单元格的数据

out.flush();

wb.write(out);

out.close();

System.out.println(row.getPhysicalNumberOfCells()+" "+row.getLastCellNum());

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} //获取d://test.xls

}

}

第三步、查看excel表格里面的内容

水红色是第一次添加的数据

深蓝色是第二次添加的数据

f561bfbab1ad0b316e48d3a15acdedc8.png

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用EasyExcel已经存在Excel表格追加数据非常简单。下面是一个简单的例子: 首先,我们需要导入EasyExcel的依赖库。可以在项目的build.gradle文件中添加以下代码: ```groovy dependencies { implementation 'com.alibaba:easyexcel:2.4.4' } ``` 然后,我们需要创建一个Java类,用于描述我们要追加数据。例如,如果我们要追加一个名为"Student"的Sheet中的数据,我们可以创建一个名为"StudentInfo"的类: ```java public class StudentInfo { private String name; private int age; private String gender; // 省略getter和setter方法 } ``` 接下来,我们可以编写代码来追加数据已经存在Excel表格中。假设我们的Excel表格已经存在,并且有一个名为"Student"的Sheet: ```java public class AppendDataExample { public static void main(String[] args) { String fileName = "path/to/existing_excel.xlsx"; String sheetName = "Student"; // 加载已经存在Excel表格,并指定要追加的Sheet名 try (ExcelWriter writer = EasyExcel.write(fileName).build()) { WriteSheet sheet = EasyExcel.writerSheet(sheetName).build(); // 构造要追加数据 List<StudentInfo> data = new ArrayList<>(); StudentInfo student1 = new StudentInfo("Tom", 18, "Male"); StudentInfo student2 = new StudentInfo("Alice", 19, "Female"); data.add(student1); data.add(student2); // 追加数据Excel表格中 writer.write(data, sheet); } } } ``` 上述代码中的"fileName"变量应该指向已经存在Excel文件的路径。代码运行后,它会读取已经存在Excel文件,并在名为"Student"的Sheet中追加指定的数据。 这就是使用EasyExcel已经存在Excel表格追加数据方法。通过构造要追加数据,并使用`ExcelWriter`类的`write`方法,我们可以很方便地实现这个功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值