Java如何利用POI读取Excel行数

 更新时间:2020年02月17日 13:54:34   作者:21Java  
这篇文章主要介绍了java如何利用POI读取Excel行数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这篇文章主要介绍了java如何利用POI读取Execel行数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

java 利用poi 读excel文件的操作,读取总的数据行数一般是通过调用 sheet.getLastRowNum() ;可是这样有时候会出现一些问题,例如,当其中一行的数据的确都为空,可是其原本的格式还在,并没有连带删除,这样计算出来的行数就不真实(比真实的大),还有当出现空白行时(也即某一行没有任何数据,通过Row row = sheet.getRow(i) 返回的row值为null),计算出来的值也不正确。

本人自己写了一个方法来对excel表进行过滤,将那些没有意义的行删掉,之后再调用sheet.getLastRowNum() 得到的值就是正确的了。

说明一下,本程序是结合自己项目的需求编写的,对于那些空白行有意义的excel文件来说,本文不存在参考价值。

package test; 
  
import java.io.FileInputStream; 
  
import org.apache.poi.hssf.usermodel.HSSFWorkbook; 
import org.apache.poi.hssf.util.CellReference; 
import org.apache.poi.ss.usermodel.Cell; 
import org.apache.poi.ss.usermodel.Row; 
import org.apache.poi.ss.usermodel.Sheet; 
import org.apache.poi.ss.usermodel.Workbook; 
  
public class test2{ 
  public static void main(String[] args) { 
    Workbook wb = null; 
    try { 
      wb = new HSSFWorkbook(new FileInputStream("E:\\Workspaces\\testdata\\仓库数据.xls")); 
    } catch (Exception e) { 
       // 
    } 
    Sheet sheet = wb.getSheetAt(0); 
    CellReference cellReference = new CellReference("A4"); 
    boolean flag = false; 
    System.out.println("总行数:"+(sheet.getLastRowNum()+1)); 
    for (int i = cellReference.getRow(); i <= sheet.getLastRowNum();) { 
      Row r = sheet.getRow(i); 
      if(r == null){ 
        // 如果是空行(即没有任何数据、格式),直接把它以下的数据往上移动 
        sheet.shiftRows(i+1, sheet.getLastRowNum(),-1); 
        continue; 
      } 
      flag = false; 
      for(Cell c:r){ 
        if(c.getCellType() != Cell.CELL_TYPE_BLANK){ 
          flag = true; 
          break; 
        } 
      } 
      if(flag){ 
        i++; 
        continue; 
      } 
      else{//如果是空白行(即可能没有数据,但是有一定格式) 
        if(i == sheet.getLastRowNum())//如果到了最后一行,直接将那一行remove掉 
          sheet.removeRow(r); 
        else//如果还没到最后一行,则数据往上移一行 
          sheet.shiftRows(i+1, sheet.getLastRowNum(),-1); 
      } 
    } 
    System.out.println("总行数:"+(sheet.getLastRowNum()+1)); 
  } 
    
}

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

相关文章

  • Java实现给网站上传图片盖章的方法

    Java实现给网站上传图片盖章的方法

    这篇文章主要介绍了Java实现给网站上传图片盖章的方法,涉及java针对图片的合成操作技巧,类似水印功能,需要的朋友可以参考下
    2015-07-07
  • 2020JDK1.8安装教程详解(一次就可安装成功)

    2020JDK1.8安装教程详解(一次就可安装成功)

    这篇文章主要介绍了2020JDK1.8安装教程详解(一次就可安装成功),本文通过图文并茂的形式分步骤给大家讲解的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2020-08-08
  • SpringBoot配置线程池的实现示例

    SpringBoot配置线程池的实现示例

    本文主要介绍了SpringBoot配置线程池的实现示例,主要包括在Spring Boot中创建和配置线程池,包括设置线程池的大小、队列容量、线程名称等参数,感兴趣的可以了解一下
    2023-09-09
  • SpringCloud组件OpenFeign之拦截器解读

    SpringCloud组件OpenFeign之拦截器解读

    这篇文章主要介绍了SpringCloud组件OpenFeign之拦截器用法。具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • HashSet和TreeSet使用方法的区别解析

    HashSet和TreeSet使用方法的区别解析

    这篇文章主要介绍了HashSet和TreeSet使用方法的区别解析,具有一定借鉴价值,需要的朋友可以参考下
    2018-01-01
  • Java里volatile关键字是什么意思

    Java里volatile关键字是什么意思

    volatile具有synchronized关键字的“可见性”,但是没有synchronized关键字的“并发正确性”,也就是说不保证线程执行的有序性。这篇文章主要介绍了Java里volatile关键字是什么意思的相关资料,需要的朋友可以参考下
    2016-11-11
  • Java 程序员容易犯的10个SQL错误

    Java 程序员容易犯的10个SQL错误

    本文介绍了Java 程序员容易犯的10个SQL错误。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • JavaWeb之Ajax的基本使用与实战案例

    JavaWeb之Ajax的基本使用与实战案例

    ajax技术是使页面能局部刷新的一种技术,下面这篇文章主要给大家介绍了关于JavaWeb之Ajax的基本使用与实战案例的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-08-08
  • Eclipse可视化插件WindowBuilder的安装方法

    Eclipse可视化插件WindowBuilder的安装方法

    这篇文章主要介绍了Eclipse可视化插件WindowBuilder的安装方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • Java经典面试题汇总:Spring

    Java经典面试题汇总:Spring

    本篇总结的是Spring框架相关的面试题,后续会持续更新,希望我的分享可以帮助到正在备战面试的实习生或者已经工作的同行,如果发现错误还望大家多多包涵,不吝赐教,谢谢
    2021-07-07

最新评论