這篇文章將為大家詳細(xì)講解有關(guān)Java中怎么利用POI讀取Excel行數(shù),文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
java 利用poi 讀excel文件的操作,讀取總的數(shù)據(jù)行數(shù)一般是通過調(diào)用 sheet.getLastRowNum() ;可是這樣有時候會出現(xiàn)一些問題,例如,當(dāng)其中一行的數(shù)據(jù)的確都為空,可是其原本的格式還在,并沒有連帶刪除,這樣計(jì)算出來的行數(shù)就不真實(shí)(比真實(shí)的大),還有當(dāng)出現(xiàn)空白行時(也即某一行沒有任何數(shù)據(jù),通過Row row = sheet.getRow(i) 返回的row值為null),計(jì)算出來的值也不正確。
本人自己寫了一個方法來對excel表進(jìn)行過濾,將那些沒有意義的行刪掉,之后再調(diào)用sheet.getLastRowNum() 得到的值就是正確的了。
說明一下,本程序是結(jié)合自己項(xiàng)目的需求編寫的,對于那些空白行有意義的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)); } }
關(guān)于Java中怎么利用POI讀取Excel行數(shù)就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
標(biāo)題名稱:Java中怎么利用POI讀取Excel行數(shù)-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://www.rwnh.cn/article10/csdpdo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、營銷型網(wǎng)站建設(shè)、建站公司、網(wǎng)站設(shè)計(jì)、網(wǎng)頁設(shè)計(jì)公司、域名注冊
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容