java实现从excel中提取某行_Java实现操作excel表格-程序员宅基地

技术标签: java实现从excel中提取某行  

最近老师布置了个任务,用Java对excel后缀名为xlsx的文件进行简单的增,删,改,查操作;虽说是个简单的程序,可作为刚接触的我来说还是有些磕磕碰碰。不过好在还是完成了,进行一个简单的总结。

首先导入了一个poi.jar 网上有很多这个资源可以下载

XSSFSheet sheet=null;

XSSFWorkbook book=null;

一:查 (查找本地指定位置的excel表格,在控制台输出)

public void print_excel(){

//获取excel表格的行数

int lastrownumber = sheet.getLastRowNum();

String ret=" ";

//获取数据

for(a=0;a

XSSFRow row=sheet.getRow(a);

//获取excel表格的列数

int lastcellnum=row.getLastCellNum();

for(b=0;b

XSSFCell cell =row.getCell(b);

//判断cell返回的类型并赋值给ret

ret=excel_operation.getExcelCellValue(cell);

System.out.print(ret+" ");

}

System.out.println();

}

}

二:改 (修改excel表格中某一单元格的内容)

public void set_excelcell(int i,int j,String str){

//获取行的信息

XSSFRow row=sheet.getRow(i-1);

//获取列的信息

XSSFCell cell =row.getCell(j-1);

//获取被修改单元格的内容

String string = excel_operation.getExcelCellValue(cell);

//修改单元格的内容为str

cell.setCellValue(str);

System.out.println("已将"+string+"改为"+str);

}

三:增 (在excel表格中插入一行内容到指定位置)

public void insert(int rowIndex, String[] objs) {

if(rowIndex == 0) {

throw new IllegalArgumentException("不能插在第0行,第0行是用来定义的!");

}

if(rowIndex > sheet.getLastRowNum() + 1) {

throw new IllegalArgumentException("最多只能插入在最后一行的后面。");

}

int referRowIndex = -1; //参考行的行号。

if(sheet.getPhysicalNumberOfRows() <= 1) {

referRowIndex = rowIndex - 1;

} else {

referRowIndex = rowIndex - 1;

if(rowIndex == sheet.getLastRowNum() + 1) { //是插入最后一行

//不做任何处理

} else {

//往下移动一位

sheet.shiftRows(rowIndex, sheet.getLastRowNum(), 1, true, false);

}

}

Row targetRow = sheet.createRow(rowIndex);

Row referRow = sheet.getRow(referRowIndex); // 参考行

Cell targetCell, referCell;

for (int i = 0; i < objs.length; i++) {

targetCell = targetRow.createCell(i);

referCell = referRow.getCell(i);

targetCell.setCellStyle(referCell.getCellStyle());

targetCell.setCellType(referCell.getCellType());

targetCell.setCellValue(objs[i]);// 设置值

}

}

四: 删 (删除指定行的内容)

// 删除一行数据(Excel表中,行是从0起算的)

public void delete(int rowIndex) {

//删除的是最后一行

if(rowIndex == sheet.getLastRowNum()) {

sheet.removeRow(sheet.getRow(sheet.getLastRowNum()));

//删除的不是最后一行

} else {

sheet.shiftRows(rowIndex + 1, sheet.getLastRowNum(), -1, true, false);

sheet.removeRow(sheet.getRow(sheet.getLastRowNum() + 1));

}

}

五: 判断返回类型 (因为excel表格中的内容不同,有字符型的,有整数型的等等,必须进行判断其类型才能进行输出)

private static String getExcelCellValue(XSSFCell cell) {

String ret=" ";

try {

//当返回值的类型为空返回空格

if (cell == null) {

ret = " ";

//当返回值的类型为字符串类型

} else if (cell.getCellType() == XSSFCell.CELL_TYPE_STRING) {

ret = cell.getStringCellValue();

//当返回值的类型为数值类型

} else if (cell.getCellType() == XSSFCell.CELL_TYPE_NUMERIC) {

ret = "" + cell.getNumericCellValue();

//当返回值的类型为表达式类型

} else if (cell.getCellType() == XSSFCell.CELL_TYPE_FORMULA) {

ret = cell.getCellFormula();

//当返回值的类型为异常类型

} else if (cell.getCellType() == XSSFCell.CELL_TYPE_ERROR) {

ret = " " + cell.getErrorCellValue();

//当返回值的类型为布尔类型

} else if (cell.getCellType() == XSSFCell.CELL_TYPE_BOOLEAN) {

ret = " " + cell.getBooleanCellValue();

//当返回值的类型为空的时候

} else if (cell.getCellType() == XSSFCell.CELL_TYPE_BLANK) {

ret = " ";

}

} catch (Exception ex) {

ex.printStackTrace();

ret = " ";

}

return ret;

}

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_39887221/article/details/114570361

智能推荐

spring-boot-starter-validation常用注解_spring-boot-starter-validation使用文档-程序员宅基地

文章浏览阅读631次,点赞18次,收藏16次。通过使用分组校验,你可以为同一个对象的不同操作设置不同的验证规则,这在复杂应用中非常有用。这种方法提高了代码的灵活性和可维护性。_spring-boot-starter-validation使用文档

word中插入高分辨率图片,并且保存为PDF图片仍然高清的方法_word保存为高清晰的pdf-程序员宅基地

文章浏览阅读5.5k次。https://blog.csdn.net/cjbct/article/details/62446380_word保存为高清晰的pdf

hadoop集群搭建(基于docker-compose)_bde2020/hadoop-程序员宅基地

文章浏览阅读4k次,点赞3次,收藏13次。1,创建工作目录比如:/home/hadoop需要配置2个文件(data是挂载目录,会自动创建)2,hadoop.env内容不用改,基本是默认配置,后续修改配置在这修改就行了,配置详情自己百度下CORE_CONF_fs_defaultFS=hdfs://namenode:8020CORE_CONF_hadoop_http_staticuser_user=rootCORE_CONF_hadoop_proxyuser_hue_hosts=*CORE_CONF_hadoop_pro_bde2020/hadoop

Cocos2d-x 窗口大小调整_cocos2dx设置窗口大小-程序员宅基地

文章浏览阅读4.2k次。打开src目录下的AppDelegate.cpp文件,若无修改则在第45行处找到全局声明的Size变量,修改`designResolutionSize`中的大小即可。_cocos2dx设置窗口大小

springboot接收枚举值的默认方式_springboot get请求怎么接收前端传递的枚举数字-程序员宅基地

文章浏览阅读1.6k次。测试代码:@PostMapping() public void test(@RequestBody Student student){ System.out.println(student.getLover().name()); }class Student{ private Lover lover; public Lover getLover() { return lover; } public void setLover_springboot get请求怎么接收前端传递的枚举数字

【数学建模笔记】【第七讲】多元线性回归分析(二):虚拟变量的设置以及交互项的解释,以及基于Stata的普通回归与标准化回归分析实例_stata两个虚拟变量的交互项-程序员宅基地

文章浏览阅读1.5w次,点赞24次,收藏120次。简单来说就是去量纲后的回归(因为你要比较不同变量之间的显著性的大小,那么带着量纲怎么比,所以先把量纲去掉,然后再比较)官话:为了更为精准的研究影响评价量的重要因素(去除量纲的影响),我们可考虑使用标准化回归系数。_stata两个虚拟变量的交互项

随便推点

一起学设计模式 - 一起开始设计模式的修炼之路_一起来学习设计模式-程序员宅基地

文章浏览阅读188次。文章目录一起学设计模式 - 一起开始设计模式的修炼之路1.为什么要学设计模式2.设计模式的六大原则2.1 单一职责原则(Single responsibility principle)2.2 开闭原则(Open Close Principle)2.3 里氏替换原则LSP(Liskov Substitution Principle)2.4 依赖倒转原则(Dependence Inversion Principle)2.5 接口隔离原则(Interface Segregation Principle)2.6 迪_一起来学习设计模式

第8课 商业需求文档(BRD)撰写方法与技巧-程序员宅基地

文章浏览阅读183次。课前提问:• BRD的内容结构有哪些?• BRD的写作内容与汇报对象有什么关系?应该有哪些注意的地方?• 不同的汇报对象,他们都关心什么样的内容?• BRD的核心重点在哪里? 8.1 BRD文档写作的目的 • BRD文档的目的– 发现• 现有产品改进的可能• 一个创新产品– 需要• 要权重• 要项目• 要资..._好的brd文档应该具备哪些特征

集成学习(Ensemble Learning)_小型数据集联合学习-程序员宅基地

文章浏览阅读4.4k次,点赞3次,收藏9次。集成学习(Ensemble Learning)  集成学习是机器学习中一个非常重要且热门的分支,是用多个弱分类器构成一个强分类器,其哲学思想是“三个臭皮匠赛过诸葛亮”。一般的弱分类器可以由决策树,神经网络,贝叶斯分类器,K-近邻等构成。这些算法可以是不同的算法,也可以是相同的算法。已经有学者理论上证明了集成学习的思想是可以提高分类器的性能的,比如说统计上的原因,计算上的原因以及表示上的原因。 ..._小型数据集联合学习

恭迎万亿级营销(圈人)潇洒的迈入毫秒时代 - 万亿user_tags级实时推荐系统数据库设计...-程序员宅基地

文章浏览阅读418次。标签PostgreSQL , 标签 , 推荐系统 , 实时圈人 , 数组 , gin , gist , 索引 , rum , tsvector , tsquery , 万亿 , user , tag , 淘宝背景我们仅用了PostgreSQL的两个小特性,却解决了业务困扰已久的大问题。推荐系统是广告营销平台的奶牛,其核心是精准、实时、..._实时圈人

软件测试风险追踪表_软件测试风险管理表格-程序员宅基地

文章浏览阅读430次。软件测试风险追踪表风险追踪表 项目名称: 填制人: 编号 风险描述 影响 风险等级 发生的可能性 应对策略 状态 责任人 备注 ..._软件测试风险管理表格

AAC ADTS封装实现-程序员宅基地

文章浏览阅读1.2k次。一、AAC音频格式种类有哪些AAC音频格式是一种由MPEG-4标准定义的有损音频压缩格式。AAC包含两种格式 ADIF(Audio Data Interchange Format音频数据交换格式)和ADTS(Audio Data transport Stream音频数据传输流)。ADIF特点:可以确定的找到音视频数据的开始,不需要进行在音视频数据流中间开始的解码,它的解码必须在明确的定义开始。应用场景:常用在磁盘文件中。ADTS特点:具有同步字的比特流,解码可以在这个流中任何位置开始。类似于mp_aac adts

推荐文章

热门文章

相关标签