(七)POI-读取excel,遍历一个工作簿
原文链接:https://blog.csdn.net/class157/article/details/92816169,https://blog.csdn.net/class157/article/details/93237963
package cases; import org.apache.poi.hssf.usermodel.HSSFCell;
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;
import org.apache.poi.ss.usermodel.*;
import org.testng.annotations.Test; import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream; /**
* @description:
* @author: lv
* @time: 2020/5/22 14:21
*/
public class DemoTest { @Test
public void testPoi()throws IOException {
//建立输入流
InputStream is = new FileInputStream("D:\\3.xls");
//接受一个输入流
POIFSFileSystem fs = new POIFSFileSystem(is);
//创建了一个工作簿
HSSFWorkbook wb = new HSSFWorkbook(fs);
//获取第一个sheet页
HSSFSheet hssfSheet = wb.getSheetAt(0);
//判断Sheet是否为空
if (hssfSheet == null) {
return;
}
//遍历行row
//continue只是终止本次循环,接着还执行后面的循环
for (int rownum = 0; rownum <= hssfSheet.getLastRowNum(); rownum++) {
//获取到每一行
HSSFRow sheetRow = hssfSheet.getRow(rownum);
if (sheetRow == null) {
continue;
}
//遍历列cell
for (int cellnum = 0; cellnum <= sheetRow.getLastCellNum(); cellnum++) {
HSSFCell cell = sheetRow.getCell(cellnum);
if (cell == null) {
continue;
}
//获取单元格的值
System.out.print(" " + getValue(cell));
}
}
}
private static String getValue(HSSFCell hssfCell) {
String cellValue = "";
if(hssfCell == null){
return cellValue;
}
//把数字当成String来读,避免出现1读成1.0的情况
hssfCell.setCellType(CellType.STRING); //hssfCell.getCellType() 获取当前列的类型
if (hssfCell.getCellType() == CellType.BOOLEAN) {
cellValue = String.valueOf(hssfCell.getBooleanCellValue());
}else if (hssfCell.getCellType() == CellType.NUMERIC) {
cellValue = String.valueOf(hssfCell.getNumericCellValue());
}else if(hssfCell.getCellType() == CellType.STRING){
cellValue = String.valueOf(hssfCell.getStringCellValue());
}else if(hssfCell.getCellType() == CellType.FORMULA){
cellValue = String.valueOf(hssfCell.getCellFormula());
}else if (hssfCell.getCellType() == CellType.BLANK){
cellValue = " ";
}else if(hssfCell.getCellType() == CellType.ERROR){
cellValue = "非法字符";
}else{
cellValue = "未知类型";
}
return cellValue;
}
}
注意点:
调用方式被弃用
cell.setCellType(HSSFCell.CELL_TYPE_NUMERIC);
可以使用这个
cell.setCellType(CellType.NUMERIC);
(七)POI-读取excel,遍历一个工作簿的更多相关文章
- java操作Excel的poi 遍历一个工作簿
遍历一个工作簿 package com.java.poi; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.h ...
- 在Excel里如何将多个工作簿合并到一个工作簿中
在Excel里如何将多个工作簿合并到一个工作簿中 当你必须将多个工作簿合并到一个工作簿时,你遇到过麻烦吗?最让人心烦的就是需要合并的工作簿里有很多张工作表.有人能推荐方法解决这个问题吗? 利用VBA ...
- EXCEL中,怎样查看一个工作簿中有几个工作表?
EXCEL中,怎样查看一个工作簿中有几个工作表 有几个EXCEL文件,每个文件(工作簿)中都有上百个工作表, 怎样可以一次性查看一个簿包含几个表? 目前好像没有直接可以看到有多少张工作表的按钮,这就需 ...
- 使用poi读取Excel文件数据
package com.haiyisoft.iecp.util; import java.io.File;import java.io.FileInputStream;import java.io.F ...
- POI读取Excel(xls、xlsx均可以)——(四)
maven构建的项目-->pom.xml文件 eclipse提供Dependencies直接添加依赖jar包的工具:直接搜索poi以及poi-ooxml即可,maven会自动依赖需要的jar包: ...
- POI读取Excel数据保存到数据库,并反馈给用户处理信息(导入带模板的数据)
今天遇到这么一个需求,将课程信息以Excel的形式导入数据库,并且课程编号再数据库中不能重复,也就是我们需要先读取Excel提取信息之后保存到数据库,并将处理的信息反馈给用户.于是想到了POI读取文件 ...
- POI读取Excel数据
POI读取Excel表格数据 * {所需相关jar下载: * commons-collections4-4.4.jar * commons-compress-1.19.jar * poi-4.1.1. ...
- Java开发小技巧(六):使用Apache POI读取Excel
前言 在数据仓库中,ETL最基础的步骤就是从数据源抽取所需的数据,这里所说的数据源并非仅仅是指数据库,还包括excel.csv.xml等各种类型的数据接口文件,而这些文件中的数据不一定是结构化存储的, ...
- 使用jxl,poi读取excel文件
作用:在java后台添加一个方法,读取导入的excel内容,根据需要返回相应的sql语句,以完成对临时表的插入操作. 使用jxl读取excel文件 package com.sixthf.bi.sapp ...
随机推荐
- 【python爬虫】scrapy入门4--添加cookies
(1) settings.py 取消注释:COOKIES_ENABLED = True (2)爬虫xx.py def parse(self, response): c_dic = {自己抓包} # 获 ...
- WordPress 安全配置
关闭后台主题编辑功能 WordPress后台的主题一旦权限开放就可以在后台直接编辑,如果没有开放则只可浏览.主机若有安装suPHP默认就是可以编辑.如果你觉得这项功能用不到,建议您可以关闭它,毕竟直接 ...
- 当.Net成为大厂门槛代码小白该何去何从?
掌握.Net已成为进入大厂的通行牌.越来越多的互联网软件公司开始使用.Net Core,根据去年数据显示腾讯.网易.顺丰.携程.中通.申通.同程艺龙.微医.233网校.问卷星.金蝶等关键业务已经在往. ...
- cp: 无法创建普通文件 : 文件已存在
背景 碰到一个偶现的编译出错问题,如图 报错的信息是 cp: 无法创建普通文件"xxx": 文件已存在 排查原因 看了下 Makefile,这句非常简单,就是 cp ./xxx . ...
- 百万年薪架构师一文整理RabbitMQ、ActiveMQ、RocketMQ、Kafka
一般来说,大型应用通常会被拆分成多个子系统,这些子系统可能会部署在多台机器上,也可能只是一台机器的多个进程中,这样的应用就是分布式应用.在讨论分布式应用时,很多初学者会把它和集群这个概念搞混,因为从部 ...
- spring框架中三层架构相关的注解
做了这么多年的C++,再去学Java,确实发现,语言都是相通的,即使是Java的那么多生态,理解起来也并不费劲 Spring 框架目前还在学习中,处于 Tourist 阶段,目前只求会做,不求原理,等 ...
- Orcle 查询语句
首先,以超级管理员的身份登录oracle sqlplus sys/bjsxt as sysdba --然后,解除对scott用户的锁 alter user scott ac ...
- jchdl - 初次使用建立项目示例
https://mp.weixin.qq.com/s/HaarKjpHan08RUTlEX0XHg 一. 下载并安装JDK 8 下载链接:https://www.oracle.com/tech ...
- doReleaseShared源码分析及唤醒后继节点的过程分析
文章结构 源码:对doReleaseShared()方法的源码进行一些注释 使用场景:介绍doReleaseShared()使用位置,及目的 以写锁开始的队列:分析写锁开始得同步等待队列在唤醒后续读锁 ...
- css 段落文字换行问题
项目中遇到的一个小问题,以前没有注意到: 超链接超出父级元素,想着给a标签加宽度但是没有效果... 后来发现两个很好用的css属性 1.word-wrap 用来控制换行 取值: (1)normal ...