欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java如何利用POI讀取Excel行數(shù)

 更新時間:2020年02月17日 13:54:34   作者:21Java  
這篇文章主要介紹了java如何利用POI讀取Excel行數(shù),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

這篇文章主要介紹了java如何利用POI讀取Execel行數(shù),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

java 利用poi 讀excel文件的操作,讀取總的數(shù)據(jù)行數(shù)一般是通過調(diào)用 sheet.getLastRowNum() ;可是這樣有時候會出現(xiàn)一些問題,例如,當(dāng)其中一行的數(shù)據(jù)的確都為空,可是其原本的格式還在,并沒有連帶刪除,這樣計算出來的行數(shù)就不真實(比真實的大),還有當(dāng)出現(xiàn)空白行時(也即某一行沒有任何數(shù)據(jù),通過Row row = sheet.getRow(i) 返回的row值為null),計算出來的值也不正確。

本人自己寫了一個方法來對excel表進行過濾,將那些沒有意義的行刪掉,之后再調(diào)用sheet.getLastRowNum() 得到的值就是正確的了。

說明一下,本程序是結(jié)合自己項目的需求編寫的,對于那些空白行有意義的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\\倉庫數(shù)據(jù).xls")); 
    } catch (Exception e) { 
       // 
    } 
    Sheet sheet = wb.getSheetAt(0); 
    CellReference cellReference = new CellReference("A4"); 
    boolean flag = false; 
    System.out.println("總行數(shù):"+(sheet.getLastRowNum()+1)); 
    for (int i = cellReference.getRow(); i <= sheet.getLastRowNum();) { 
      Row r = sheet.getRow(i); 
      if(r == null){ 
        // 如果是空行(即沒有任何數(shù)據(jù)、格式),直接把它以下的數(shù)據(jù)往上移動 
        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{//如果是空白行(即可能沒有數(shù)據(jù),但是有一定格式) 
        if(i == sheet.getLastRowNum())//如果到了最后一行,直接將那一行remove掉 
          sheet.removeRow(r); 
        else//如果還沒到最后一行,則數(shù)據(jù)往上移一行 
          sheet.shiftRows(i+1, sheet.getLastRowNum(),-1); 
      } 
    } 
    System.out.println("總行數(shù):"+(sheet.getLastRowNum()+1)); 
  } 
    
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 關(guān)于SpringBoot配置文件application.properties的路徑問題

    關(guān)于SpringBoot配置文件application.properties的路徑問題

    這篇文章主要介紹了關(guān)于SpringBoot配置文件application.properties的路徑問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • SpringAMQP消息隊列(SpringBoot集成RabbitMQ方式)

    SpringAMQP消息隊列(SpringBoot集成RabbitMQ方式)

    這篇文章主要介紹了SpringAMQP消息隊列(SpringBoot集成RabbitMQ方式),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • MyBatisPlus超詳細分析條件查詢

    MyBatisPlus超詳細分析條件查詢

    這篇文章主要介紹了MyBatisPlus條件查詢的使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • jdk17?SpringBoot?JPA集成多數(shù)據(jù)庫的示例詳解

    jdk17?SpringBoot?JPA集成多數(shù)據(jù)庫的示例詳解

    這篇文章主要介紹了jdk17?SpringBoot?JPA集成多數(shù)據(jù)庫的示例代碼,包括配置類、請求攔截器、線程上下文等相關(guān)知識,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • Java找出1000以內(nèi)的所有完數(shù)

    Java找出1000以內(nèi)的所有完數(shù)

    一個數(shù)如果恰好等于它的因子之和,這個數(shù)就稱為 "完數(shù) "。例如6=1+2+3.編程找出1000以內(nèi)的所有完數(shù)
    2017-02-02
  • JAVA多線程之中斷機制stop()、interrupted()、isInterrupted()

    JAVA多線程之中斷機制stop()、interrupted()、isInterrupted()

    這篇文章主要介紹了JAVA多線程之中斷機制stop()、interrupted()、isInterrupted()的相關(guān)資料,需要的朋友可以參考下
    2016-05-05
  • Maven 錯誤找不到符號的解決方法

    Maven 錯誤找不到符號的解決方法

    這篇文章主要介紹了Maven 錯誤找不到符號的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 使用Springboot自定義注解,支持SPEL表達式

    使用Springboot自定義注解,支持SPEL表達式

    這篇文章主要介紹了使用Springboot自定義注解,支持SPEL表達式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • Spring Boot 集成 Mybatis Plus 自動填充字段的實例詳解

    Spring Boot 集成 Mybatis Plus 自動填充字段的實例詳解

    這篇文章主要介紹了Spring Boot 集成 Mybatis Plus 自動填充字段,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • k8s+springboot+CronJob定時任務(wù)部署實現(xiàn)

    k8s+springboot+CronJob定時任務(wù)部署實現(xiàn)

    本文主要介紹了k8s+springboot+CronJob定時任務(wù)部署實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07

最新評論