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

java poi判斷excel是xlsx還是xls類型

 更新時(shí)間:2024年10月29日 15:55:09   作者:java_丫丫程序媛  
這篇文章主要為大家詳細(xì)介紹了如何利用java poi來判斷excel是xlsx還是xls類型,文中的示例代碼講解詳細(xì),有需要的小伙伴可以參考一下

java poi判斷excel是xlsx還是xls

依賴

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>5.2.5</version>
</dependency>

代碼

package com.test.excel;
 
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
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;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
 
import java.io.File;
import java.nio.file.Files;
 
public class ExcelRateOneTest {
 
    public static void main(String[] args) {
        File file = new File("D:\\年輕干部人才庫名冊(cè).xls");
        try {
            Workbook workbook = null;
            try {
                workbook = new XSSFWorkbook(Files.newInputStream(file.toPath()));
            } catch (Exception e) {
                System.out.println("該excel文件不是xlsx類型"+e.getMessage());
            }
            try {
                if (null == workbook) {
                    workbook = new HSSFWorkbook(Files.newInputStream(file.toPath()));
                }
            } catch (Exception e) {
                System.out.println("該文件不是excel文件"+e.getMessage());
            }
            if (workbook != null) {
                Sheet sheet = workbook.getSheetAt(0);
                Row row = sheet.getRow(0);
                Cell cell = row.getCell(0);
                System.out.println("單元格內(nèi)容:" + getCellValue(cell));
            }
        }catch (Exception e){
            System.out.println(e.getMessage());
        }
    }
 
    /**
     * 根據(jù)單元格類型獲取單元格內(nèi)容,將內(nèi)容轉(zhuǎn)為字符串類型
     * @param cell 單元格
     * @return
     */
    public static String getCellValue(Cell cell) {
        if (cell == null) {
            return "";
        }
        switch (cell.getCellType()) {
            case STRING:
                return cell.getStringCellValue();
            case NUMERIC:
                return cell.getNumericCellValue() + "";
            case BOOLEAN:
                return cell.getBooleanCellValue() + "";
            case FORMULA:
                return cell.getCellFormula() + "";
            default:
                return "";
        }
    }
}

知識(shí)補(bǔ)充

除了上文的內(nèi)容,小編還為大家整理了Java利用poi解析xlsx和xls文件的相關(guān)代碼,希望對(duì)大家有所幫助

遇到過處理excel的問題,在網(wǎng)上找了很久,感覺他們的代碼太亂太復(fù)雜,這是我精簡(jiǎn)版的excel處理代碼,簡(jiǎn)單暴力。

首先,為什么使用poi?jxl只能處理03版之前的excel,也就是xls結(jié)尾的,不能處理xlsx。poi兼容兩種格式,poi解析兩種格式的文件時(shí),唯一的不同就是xls時(shí),為HSSF;xlsx時(shí),為XSSF。

首先是處理Cell對(duì)象的小方法:

//這個(gè)方法對(duì)cell進(jìn)行處理,傳入cell對(duì)象,返回cell中內(nèi)容,String類型。
public static String getCellFormatValue(Cell cell) {
		String cellValue = "";
		if (cell != null) {
			// 判斷cell類型
			switch (cell.getCellType()) {
			case Cell.CELL_TYPE_NUMERIC: {
				cellValue = String.valueOf(cell.getNumericCellValue());
				break;
			}
			case Cell.CELL_TYPE_STRING: {
				cellValue = cell.getRichStringCellValue().getString();
				break;
			}
			default:
				cellValue = "";
			}
		}
		return cellValue;
	}

兩種處理excel的代碼:

xls時(shí):

InputStream inputStream = new FileInputStream("絕對(duì)路徑.xls");
		HSSFWorkbook workbook = new HSSFWorkbook(inputStream);
		HSSFSheet s = workbook.getSheetAt(0);
		for (int j = 0; j < s.getPhysicalNumberOfRows(); j++) {//獲取總行數(shù)
			Row row = s.getRow(j); // 取出第i行 getRow(index) 獲取第(j)行
			for (int k = 0; k < row.getPhysicalNumberOfCells(); k++) { // getPhysicalNumberOfCells() 獲取當(dāng)前行的總列數(shù)
				String value1 = getCellFormatValue(row.getCell(k));//取出第j行第k列的值
				System.out.println(value1);
			}
		}
		workbook.close();

xlsx時(shí):

InputStream inputStream = new FileInputStream("絕對(duì)路徑.xlsx");
		XSSFWorkbook workbook = new XSSFWorkbook(inputStream);
		XSSFSheet s = workbook.getSheetAt(0);
		for (int j = 0; j < s.getPhysicalNumberOfRows(); j++) {//獲取總行數(shù)
			Row row = s.getRow(j); // 取出第i行 getRow(index) 獲取第(j)行
			for (int k = 0; k < row.getPhysicalNumberOfCells(); k++) { // getPhysicalNumberOfCells() 獲取當(dāng)前行的總列數(shù)
				String value1 = getCellFormatValue(row.getCell(k));//取出第j行第k列的值
				System.out.println(value1);
			}
		}
		workbook.close();

以上就是java poi判斷excel是xlsx還是xls類型的詳細(xì)內(nèi)容,更多關(guān)于java判斷excel是xlsx還是xls的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • SpringMVC中請(qǐng)求參數(shù)的獲取方式

    SpringMVC中請(qǐng)求參數(shù)的獲取方式

    這篇文章主要為大家介紹了SpringMVC中請(qǐng)求參數(shù)的獲取方式,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Java流形式返回前端的實(shí)現(xiàn)示例

    Java流形式返回前端的實(shí)現(xiàn)示例

    ? Java后端開發(fā)項(xiàng)目時(shí),需要給前端傳一些數(shù)據(jù),本文主要介紹了Java流形式返回前端的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • 手把手教你實(shí)現(xiàn)Java第三方應(yīng)用登錄

    手把手教你實(shí)現(xiàn)Java第三方應(yīng)用登錄

    本文主要介紹了手把手教你實(shí)現(xiàn)Java第三方應(yīng)用登錄,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Java中實(shí)現(xiàn)接口與繼承的區(qū)別及說明

    Java中實(shí)現(xiàn)接口與繼承的區(qū)別及說明

    這篇文章主要介紹了Java中實(shí)現(xiàn)接口與繼承的區(qū)別及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • SpringBoot2.0整合Redis自定義注入bean組件配置的實(shí)戰(zhàn)教程

    SpringBoot2.0整合Redis自定義注入bean組件配置的實(shí)戰(zhàn)教程

    這篇文章主要介紹了SpringBoot2.0整合Redis自定義注入bean組件配置,我們將基于SpringBoot2.0整合搭建的微服務(wù)項(xiàng)目為奠基,開啟中間件Redis的實(shí)戰(zhàn)之路,需要的朋友可以參考下
    2023-06-06
  • Java類的初始化順序知識(shí)點(diǎn)總結(jié)

    Java類的初始化順序知識(shí)點(diǎn)總結(jié)

    在本篇文章里小編給大家整理的是關(guān)于Java類的初始化順序知識(shí)點(diǎn)總結(jié),需要的朋友們可以學(xué)習(xí)下。
    2020-02-02
  • JVM的類加載過程以及雙親委派模型詳解

    JVM的類加載過程以及雙親委派模型詳解

    這篇文章主要介紹了JVM的類加載過程以及雙親委派模型詳解,類加載器就是根據(jù)指定全限定名稱將 class 文件加載到 JVM 內(nèi)存,然后再轉(zhuǎn)化為 class 對(duì)象。,需要的朋友可以參考下
    2019-06-06
  • spring data jpa @Query注解中delete語句報(bào)錯(cuò)的解決

    spring data jpa @Query注解中delete語句報(bào)錯(cuò)的解決

    這篇文章主要介紹了spring data jpa @Query注解中delete語句報(bào)錯(cuò)的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • application.yml和bootstrap.yml不生效的3種解決方案

    application.yml和bootstrap.yml不生效的3種解決方案

    SpringBoot默認(rèn)支持?properties(.properties) 和 YAML(.yml .yaml ) 配置文件,本文主要介紹了application.yml和bootstrap.yml不生效的3種解決方案,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • Java讀取json數(shù)據(jù)并存入數(shù)據(jù)庫的操作代碼

    Java讀取json數(shù)據(jù)并存入數(shù)據(jù)庫的操作代碼

    很多朋友問大佬們JAVA怎么把json存入數(shù)據(jù)庫啊,這一問題就把我難倒了,糾結(jié)如何操作呢,下面小編把我的經(jīng)驗(yàn)分享給大家,感興趣的朋友一起看看吧
    2021-08-08

最新評(píng)論