真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java中怎么利用POI讀取Excel行數(shù)-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)Java中怎么利用POI讀取Excel行數(shù),文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

目前創(chuàng)新互聯(lián)已為近1000家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)頁(yè)空間、網(wǎng)站托管維護(hù)、企業(yè)網(wǎng)站設(shè)計(jì)、湯陰網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

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

本人自己寫(xiě)了一個(gè)方法來(lái)對(duì)excel表進(jìn)行過(guò)濾,將那些沒(méi)有意義的行刪掉,之后再調(diào)用sheet.getLastRowNum() 得到的值就是正確的了。

說(shuō)明一下,本程序是結(jié)合自己項(xiàng)目的需求編寫(xiě)的,對(duì)于那些空白行有意義的excel文件來(lái)說(shuō),本文不存在參考價(jià)值。

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\\倉(cāng)庫(kù)數(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){        // 如果是空行(即沒(méi)有任何數(shù)據(jù)、格式),直接把它以下的數(shù)據(jù)往上移動(dòng)        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{//如果是空白行(即可能沒(méi)有數(shù)據(jù),但是有一定格式)        if(i == sheet.getLastRowNum())//如果到了最后一行,直接將那一行remove掉          sheet.removeRow(r);        else//如果還沒(méi)到最后一行,則數(shù)據(jù)往上移一行          sheet.shiftRows(i+1, sheet.getLastRowNum(),-1);      }    }    System.out.println("總行數(shù):"+(sheet.getLastRowNum()+1));  } }

關(guān)于Java中怎么利用POI讀取Excel行數(shù)就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。


本文標(biāo)題:Java中怎么利用POI讀取Excel行數(shù)-創(chuàng)新互聯(lián)
URL網(wǎng)址:http://weahome.cn/article/csdpdo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部