亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java之如何讀取Excel獲取真實行數(shù)

 更新時間:2023年06月09日 09:59:53   作者:imadxu  
這篇文章主要介紹了Java之如何讀取Excel獲取真實行數(shù)問題,具有很好的參考價值,希望對大家有所幫助。

Java讀取Excel獲取真實行數(shù)

剛進入公司開發(fā),熟悉環(huán)境是個很大的難題,今天就接到了一個任務,讓我修改批量上傳excel文件的頁面.

公司采用的是apache提供的包,通過XML文件的映射,把EXCEL表和我們的Model對應起來.本來是校驗正確的,結果莫名其妙到后面就會報空指針異常.

問題的原因:在沒有格式的前提下,getLastRowNum方法能夠正確返回最后一行的位置;getPhysicalNumberOfRows方法能夠正確返回物理的行數(shù);

* 在有格式的前提下,這兩個方法都是不合理的;

* 所以,在做導入excel的時候,建議想要正確獲取行數(shù),可以做一個人為的約定,比如約定導入文件第一列不允許為空,行數(shù)就按照第一列的有效行數(shù)來統(tǒng)計;這樣就能正確獲取到實際想要的行數(shù);

更新版本,因為發(fā)現(xiàn)有時候 存在了加了樣式的邊框,邊框的屬性默認成為了 公式屬性,導致后面空指針,現(xiàn)已修復

修改版

    /**
     * 用來得到真實行數(shù)
     * @param sheet
     * @param flag  需要寫進數(shù)據(jù)庫的列數(shù)用逗號隔開 比如  (Sheet sheet,int 2,int 3);隨意個
     * @return
     * 
     */
public static int findRealRows(Sheet sheet, int... flag) {
        int row_real = 0;
        int rows = sheet.getPhysicalNumberOfRows();// 此處物理行數(shù)統(tǒng)計有錯誤,
        int size = flag.length;
        try {
        for (int i = 1; i < rows; i++) {
            Row row = sheet.getRow(i);
            int total = 0;
            ArrayList<Integer> blank =new ArrayList<Integer>();
            int type=-1;
            String s = null;
            for(int j:flag){
                if(!(row.getCell(j) == null)&&row.getCell(j).getCellType()<2){
                    type=row.getCell(j).getCellType();
                    row.getCell(j).setCellType(1);
                }
                if (row.getCell(j) == null||row.getCell(j).getStringCellValue().matches("^\\s+$")||row.getCell(j).getCellType()>2) {
                    total++;
                    if(!(row.getCell(j) == null)&&row.getCell(j).getCellType()<2){
                    row.getCell(j).setCellType(type);
                    }
                    blank.add(j);
                }
            }
            System.out.println(s+"我");
            // 如果4列都是空說明就該返回
            if (total == flag.length) {
                return row_real;
            } else if (total == 0) {
                row_real++;
            } else {
                String h="";
                for(Integer b:blank){
                     h=h+"第"+(b+1)+"列"+" ";
                }
                throw new BusinessException("第" + (i + 1) + "行" + h
                        + "不能為空");
            }
        }
        } catch (NullPointerException e) {
            throw new BusinessException("excel格式異常,請檢查excel格式有無數(shù)據(jù)缺失,無效數(shù)據(jù)行!");
        }
        return row_real;
    }

方法都這樣,通過約定一個有的ID來進行判斷,可以較快的得到真實的行數(shù) ,以至于后面的集合循環(huán)輸出的話不會出現(xiàn)空指針異常

Java讀取excel數(shù)據(jù)

導入相關的MAVEN依賴。

? ? ? ? <!--excel的依賴-->
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>org.apache.poi</groupId>
? ? ? ? ? ? <artifactId>poi</artifactId>
? ? ? ? ? ? <version>4.1.0</version>
? ? ? ? </dependency>
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>org.apache.poi</groupId>
? ? ? ? ? ? <artifactId>poi-ooxml</artifactId>
? ? ? ? ? ? <version>4.1.0</version>
? ? ? ? </dependency>

Java代碼

使用說明:

1、XSSFWorkbook是整個操作excel文件需要用到的對象。構造時,參數(shù)是一個FileInputStream對象,里面寫上文件的地址。

2、getNumberOfSheets()獲取擁有的sheet總頁數(shù)。

3、getSheetAt(number)操作第幾個工作簿,參數(shù)是第幾個sheet表。此處的參數(shù)索引是從0開始。返回值是一個工作簿對象XSSFSheet,用于操作這個工作簿。

4、工作簿對象.getLastRowNum()。獲取該工作簿一共有多少列。

5、getRow(row_num).getLastCellNum().獲取改行共有多少列。此處行和列的下標都是從1開始的。

6、getRow(row).getCell(rol)。獲取改行該列的元素。

? ?public static void excelFind() {
? ? ? ? try {
? ? ? ? ? ? XSSFWorkbook xssfWorkbook = new XSSFWorkbook(new FileInputStream("src/test/java/postSQL/database/test.xlsx"));
? ? ? ? ? ? //獲取工作簿下sheet的個數(shù)
? ? ? ? ? ? int sheetNum = xssfWorkbook.getNumberOfSheets();
? ? ? ? ? ? System.out.println("總數(shù)頁碼:"+sheetNum);
? ? ? ? ? ? //遍歷頁碼:
? ? ? ? ? ? for(int i = 0;i<sheetNum;i++) {
? ? ? ? ? ? ? ? System.out.println("讀取第"+(i+1)+"個sheet");
? ? ? ? ? ? ? ? //sheet的索引下標是從0開始的,得到該頁碼的對象
? ? ? ? ? ? ? ? XSSFSheet sheet = xssfWorkbook.getSheetAt(i);
? ? ? ? ? ? ? ? //獲取總共的行數(shù)
? ? ? ? ? ? ? ? int maxRow = sheet.getLastRowNum();
? ? ? ? ? ? ? ? //對每一行進行遍歷
? ? ? ? ? ? ? ? for (int row = 0; row <= maxRow; row++) {
? ? ? ? ? ? ? ? ? ? //getRow(row_num)獲取改行的對象,再.getLastCellNum()獲取該行共有幾列
? ? ? ? ? ? ? ? ? ? //此處與sheet不同的是,該索引下標是從1開始的
? ? ? ? ? ? ? ? ? ? int maxRol = sheet.getRow(row).getLastCellNum();
? ? ? ? ? ? ? ? ? ? System.out.println("--------第" + row + "行的數(shù)據(jù)如下--------");
? ? ? ? ? ? ? ? ? ? //遍歷列數(shù)
? ? ? ? ? ? ? ? ? ? for (int rol = 0; rol < maxRol; rol++){
? ? ? ? ? ? ? ? ? ? ? ? //sheets.getRow(1).getCell(1);獲取元素值
? ? ? ? ? ? ? ? ? ? ? ? System.out.print(sheet.getRow(row).getCell(rol) + " ?");
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? System.out.println();
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? } catch (IOException e) {
? ? ? ? ? ? e.printStackTrace();
? ? ? ? }
? ? }

總結

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • window系統(tǒng)安裝jdk jre的教程圖解

    window系統(tǒng)安裝jdk jre的教程圖解

    java開發(fā)少不了安裝jdk,jdk可以同時安裝多個版本,只要在項目部署時注意切換版本選擇,下面小編給大家?guī)砹藈indow系統(tǒng)安裝jdk jre的教程圖解,感興趣的朋友一起看看吧
    2018-08-08
  • java 圖片與base64相互轉化的示例

    java 圖片與base64相互轉化的示例

    這篇文章主要介紹了java 圖片與base64相互轉化的示例,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2020-10-10
  • Java實戰(zhàn)項目 健身管理系統(tǒng)

    Java實戰(zhàn)項目 健身管理系統(tǒng)

    本文是一個Java語言編寫的實戰(zhàn)項目,是一個健身管理系統(tǒng),主要用到了ssm+springboot等技術,技術含量筆記高,感興趣的童鞋跟著小編往下看吧
    2021-09-09
  • RestTemplate請求失敗自動重啟機制精講

    RestTemplate請求失敗自動重啟機制精講

    這篇文章主要為大家介紹了RestTemplate請求失敗自定義處理的方法,自動重試的機制精講,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多所進步,早日升職加薪
    2022-03-03
  • 詳解Java中用于國際化的locale類

    詳解Java中用于國際化的locale類

    Java中也有用于轉換和劃分地區(qū)的國際化類java.lang.Locale,國際化在程序中設置語言和時間等時非常有用,下面我們就來詳解Java中用于國際化的locale類
    2016-06-06
  • 半小時實現(xiàn)Java手擼網(wǎng)絡爬蟲框架(附完整源碼)

    半小時實現(xiàn)Java手擼網(wǎng)絡爬蟲框架(附完整源碼)

    最近在做一個搜索相關的項目,需要爬取網(wǎng)絡上的一些鏈接存儲到索引庫中,自己寫了一個簡單的網(wǎng)絡爬蟲,感興趣的可以了解一下
    2021-06-06
  • SpringMVC MVC架構與Servlet使用詳解

    SpringMVC MVC架構與Servlet使用詳解

    MVC設計模式一般指 MVC 框架,M(Model)指數(shù)據(jù)模型層,V(View)指視圖層,C(Controller)指控制層。使用 MVC 的目的是將 M 和 V 的實現(xiàn)代碼分離,使同一個程序可以有不同的表現(xiàn)形式。其中,View 的定義比較清晰,就是用戶界面
    2022-10-10
  • Mybatis Criteria使用and和or進行聯(lián)合條件查詢的操作方法

    Mybatis Criteria使用and和or進行聯(lián)合條件查詢的操作方法

    這篇文章主要介紹了Mybatis Criteria的and和or進行聯(lián)合條件查詢的方法,本文通過例子給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10
  • JAVA為什么要使用封裝及如何封裝經(jīng)典實例

    JAVA為什么要使用封裝及如何封裝經(jīng)典實例

    這篇文章主要給大家介紹了關于JAVA為什么要使用封裝及如何封裝的相關資料,封裝就是將屬性私有化,提供公有的方法訪問私有屬性,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-10-10
  • Java創(chuàng)建,編輯與刪除Excel迷你圖表的實現(xiàn)方法

    Java創(chuàng)建,編輯與刪除Excel迷你圖表的實現(xiàn)方法

    迷你圖是Excel工作表單元格中表示數(shù)據(jù)的微型圖表。本文將通過Java代碼示例介紹如何在Excel中創(chuàng)建迷你圖表,以及編輯和刪除表格中的迷你圖表,需要的可以參考一下
    2022-05-05

最新評論