利用Apache POI在已有的Excel文件中插入一行新的数据

2024-05-25 23:38

本文主要是介绍利用Apache POI在已有的Excel文件中插入一行新的数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在POI的第一节入门中,我们提供了两个简单的例子,一个是如何用Apache POI新建一个工作薄,另外一个例子是,如果用Apache POI新建一个工作表。那么在这个章节里面,我将会给大家演示一下,如何用Apache POI在已有的Excel文件中插入一行新的数据。具体代码,请看下面的例子。

[java] view plain copy
print ?
  1. import java.io.File;  
  2. import java.io.FileInputStream;  
  3. import java.io.FileNotFoundException;  
  4. import java.io.FileOutputStream;  
  5. import java.io.IOException;  
  6.   
  7. import org.apache.poi.xssf.usermodel.XSSFCell;  
  8. import org.apache.poi.xssf.usermodel.XSSFRow;  
  9. import org.apache.poi.xssf.usermodel.XSSFSheet;  
  10. import org.apache.poi.xssf.usermodel.XSSFWorkbook;  
  11.   
  12. public class CreatRowTest {  
  13.     //当前文件已经存在  
  14.     private String excelPath = “D:\\exceltest\\comments.xlsx”;  
  15.     //从第几行插入进去  
  16.     private int insertStartPointer = 3;  
  17.     //在当前工作薄的那个工作表单中插入这行数据   
  18.     private String sheetName = “Sheet1”;  
  19.   
  20.     /** 
  21.      * 总的入口方法 
  22.      */  
  23.     public static void main(String[] args) {  
  24.         CreatRowTest crt = new CreatRowTest();  
  25.         crt.insertRows();  
  26.     }  
  27.     /** 
  28.      * 在已有的Excel文件中插入一行新的数据的入口方法 
  29.      */  
  30.     public void insertRows() {  
  31.         XSSFWorkbook wb = returnWorkBookGivenFileHandle();  
  32.         XSSFSheet sheet1 = wb.getSheet(sheetName);  
  33.         XSSFRow row = createRow(sheet1, insertStartPointer);  
  34.         createCell(row);  
  35.         saveExcel(wb);  
  36.   
  37.     }  
  38.     /** 
  39.      * 保存工作薄 
  40.      * @param wb 
  41.      */  
  42.     private void saveExcel(XSSFWorkbook wb) {  
  43.         FileOutputStream fileOut;  
  44.         try {  
  45.             fileOut = new FileOutputStream(excelPath);  
  46.             wb.write(fileOut);  
  47.             fileOut.close();  
  48.         } catch (FileNotFoundException e) {  
  49.             e.printStackTrace();  
  50.         } catch (IOException e) {  
  51.             e.printStackTrace();  
  52.         }  
  53.   
  54.     }  
  55.     /** 
  56.      * 创建要出入的行中单元格 
  57.      * @param row 
  58.      * @return 
  59.      */  
  60.     private XSSFCell createCell(XSSFRow row) {  
  61.         XSSFCell cell = row.createCell((short0);  
  62.         cell.setCellValue(999999);  
  63.         row.createCell(1).setCellValue(1.2);  
  64.         row.createCell(2).setCellValue(“This is a string cell”);  
  65.         return cell;  
  66.     }  
  67.    /** 
  68.     * 得到一个已有的工作薄的POI对象 
  69.     * @return 
  70.     */  
  71.     private XSSFWorkbook returnWorkBookGivenFileHandle() {  
  72.         XSSFWorkbook wb = null;  
  73.         FileInputStream fis = null;  
  74.         File f = new File(excelPath);  
  75.         try {  
  76.             if (f != null) {  
  77.                 fis = new FileInputStream(f);  
  78.                 wb = new XSSFWorkbook(fis);  
  79.             }  
  80.         } catch (Exception e) {  
  81.             return null;  
  82.         } finally {  
  83.             if (fis != null) {  
  84.                 try {  
  85.                     fis.close();  
  86.                 } catch (IOException e) {  
  87.                     e.printStackTrace();  
  88.                 }  
  89.             }  
  90.         }  
  91.         return wb;  
  92.     }  
  93.    /** 
  94.     * 找到需要插入的行数,并新建一个POI的row对象 
  95.     * @param sheet 
  96.     * @param rowIndex 
  97.     * @return 
  98.     */  
  99.     private XSSFRow createRow(XSSFSheet sheet, Integer rowIndex) {  
  100.         XSSFRow row = null;  
  101.         if (sheet.getRow(rowIndex) != null) {  
  102.             int lastRowNo = sheet.getLastRowNum();  
  103.             sheet.shiftRows(rowIndex, lastRowNo, 1);  
  104.         }  
  105.         row = sheet.createRow(rowIndex);  
  106.         return row;  
  107.     }  
  108.   
  109.       
  110.   
  111. }  
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;public class CreatRowTest {//当前文件已经存在private String excelPath = "D:\\exceltest\\comments.xlsx";//从第几行插入进去private int insertStartPointer = 3;//在当前工作薄的那个工作表单中插入这行数据 private String sheetName = "Sheet1";/*** 总的入口方法*/public static void main(String[] args) {CreatRowTest crt = new CreatRowTest();crt.insertRows();}/*** 在已有的Excel文件中插入一行新的数据的入口方法*/public void insertRows() {XSSFWorkbook wb = returnWorkBookGivenFileHandle();XSSFSheet sheet1 = wb.getSheet(sheetName);XSSFRow row = createRow(sheet1, insertStartPointer);createCell(row);saveExcel(wb);}/*** 保存工作薄* @param wb*/private void saveExcel(XSSFWorkbook wb) {FileOutputStream fileOut;try {fileOut = new FileOutputStream(excelPath);wb.write(fileOut);fileOut.close();} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}}/*** 创建要出入的行中单元格* @param row* @return*/private XSSFCell createCell(XSSFRow row) {XSSFCell cell = row.createCell((short) 0);cell.setCellValue(999999);row.createCell(1).setCellValue(1.2);row.createCell(2).setCellValue("This is a string cell");return cell;}/*** 得到一个已有的工作薄的POI对象* @return*/private XSSFWorkbook returnWorkBookGivenFileHandle() {XSSFWorkbook wb = null;FileInputStream fis = null;File f = new File(excelPath);try {if (f != null) {fis = new FileInputStream(f);wb = new XSSFWorkbook(fis);}} catch (Exception e) {return null;} finally {if (fis != null) {try {fis.close();} catch (IOException e) {e.printStackTrace();}}}return wb;}/*** 找到需要插入的行数,并新建一个POI的row对象* @param sheet* @param rowIndex* @return*/private XSSFRow createRow(XSSFSheet sheet, Integer rowIndex) {XSSFRow row = null;if (sheet.getRow(rowIndex) != null) {int lastRowNo = sheet.getLastRowNum();sheet.shiftRows(rowIndex, lastRowNo, 1);}row = sheet.createRow(rowIndex);return row;}}


                </div>

这篇关于利用Apache POI在已有的Excel文件中插入一行新的数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1002940

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个