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

java解析Excel文件的方法實(shí)例詳解

 更新時(shí)間:2022年06月20日 10:38:45   作者:AyaoJies?杰  
在日常工作中,我們常常會(huì)進(jìn)行文件讀寫(xiě)操作,除去我們最常用的純文本文件讀寫(xiě),更多時(shí)候我們需要對(duì)Excel中的數(shù)據(jù)進(jìn)行讀取操作,下面這篇文章主要給大家介紹了關(guān)于java解析Excel文件的方法,需要的朋友可以參考下

在做一個(gè)項(xiàng)目時(shí),有很多原本保存在Excel文件中的基礎(chǔ)數(shù)據(jù),如此則需要一個(gè)Excel文件解析并獲取數(shù)據(jù),轉(zhuǎn)存至數(shù)據(jù)庫(kù)的功能,話(huà)不多說(shuō),上代碼

介紹

使用org.apache.poi依賴(lài),我自己寫(xiě)了兩個(gè)類(lèi)來(lái)實(shí)現(xiàn)對(duì)Excel文件的解析,重要的寫(xiě)前邊,后邊附加Controller與前端Element-ui的標(biāo)簽實(shí)現(xiàn)的文件上傳與接收

1.1 pom依賴(lài)

沒(méi)啥可說(shuō)的吧,加到pom文件中刷新maven依賴(lài)即可

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>自行選擇依賴(lài)版本</version>
    < !-- 可用版本:4.1.2  --->
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-scratchpad</artifactId>
    <version>自行選擇依賴(lài)版本</version>
    < !-- 可用版本:4.1.2  --->
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>自行選擇依賴(lài)版本</version>
    < !-- 可用版本:4.1.2  --->
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml-schemas</artifactId>
    <version>自行選擇依賴(lài)版本</version>
    < !-- 可用版本:4.1.2  --->
</dependency>

1.2 將數(shù)據(jù)流轉(zhuǎn)化為可解析的Workbook類(lèi)型文件

/**
* 將EXCEL文件轉(zhuǎn)化為java可操作的Workbook類(lèi)型
* @param file Excel文件的流對(duì)象
* @return Workbook workbook java可以操縱的文件類(lèi)型
*/
public Workbook getWorkbook(MultipartFile file){
    //獲取文件類(lèi)型,即文件名后綴,通過(guò)獲取文件名并用.分割文件名,并取用返回值的第二個(gè)下標(biāo)1
    String fileType = file.getOriginalFilename().split("\\.")[1];
    Workbook workbook = new XSSFWorkbook();
    try{
        if(fileType.equals("xls")){workbook = new HSSFWorkbook(file.getInputStream());}
        else if(fileType.equals("xlsx")){workbook = new XSSFWorkbook(file.getInputStream());}
        else {return null;}
    }catch(Exception e){return null;}
    return workbook;
}

1.3 解析

/**
* 獲取Excel文件的數(shù)據(jù)并將數(shù)據(jù)以L(fǎng)ist<map<String,String>>的格式返回?cái)?shù)據(jù),每一個(gè)map代表一行數(shù)據(jù)
* @Param workbook 需要操作的Excel文件
* @Param colNames 列名數(shù)組,需要該Excel表的每一列所對(duì)應(yīng)的信息(將作為map的key值)
* @param SheetNum 需要使用的是Excel的第幾張表
* @return
*/
public List<Map<String,String>> getExcelValues(Workbook workbook,String[] colNames,int SheetNum){
    //初始化基礎(chǔ)數(shù)據(jù)
    List<Map<String,String>> list = new ArrayList<>();    //用于存儲(chǔ)最終結(jié)果
    Map<String,String> map = new HashMap<>();    //用于逐一存儲(chǔ)表格的每一行數(shù)據(jù)
    Sheet sheet = workbook.getSgeetAt(SheetNum);    //獲取Excel文件的表格
    int rowNum = sheet.getPhysicalNumberOfRows();    //獲取當(dāng)前表格最大行數(shù)
    //循環(huán)遍歷表格的每一行,獲取每一行的值(i的初始值決定從表格的第幾行開(kāi)始)
    for(int i = 0 ; i < rowNum ; i ++){
        map = new HashMap<>();    //清除map中的數(shù)據(jù)
        Row row = sheet.getRow(i);    //獲取表格中第i行的數(shù)據(jù)
        //循環(huán)遍歷表格第i行的每一個(gè)單元格的值(j的初始值決定從表格的第幾列開(kāi)始)
        for(int j = 0 ; j < colNames.length ; j ++){
            try{    //這里可能會(huì)報(bào)錯(cuò),try{}catch{}一下
                cellData = (String)row.getCell(j).getStringCellValue();
            }catch(Exception e){
                try{    //如果某一個(gè)單元格為純數(shù)字的字符串時(shí)會(huì)報(bào)錯(cuò),需特殊處理
                    String[] a = new DecimalFormat().format(row.getCell(j).getNumericCellValue()).split(",");
                    cellData = a[0]
                    for(int k = 1; k < a.length ; k++){
                        cellData += a[k];
                    }
                }catch(Exception e){
                    cellData = null;
                }
            }
            map.put(colNames[j],cellData);        //將第i行第j個(gè)單元格數(shù)據(jù)存入map中
        }
        list.add(map);    //將第i行數(shù)據(jù)存入list中
    }
    return list;
}

1.4 Controller層接收前端傳遞的Excel文件(前端使用Element-ui的<el-upload>組件)

@PostMapping("/uploadExcel")
public Result uploadExcel(@RequestParam("file") MultipartFile file){
    List<Map<String,String>> list = uploadService.uploadExcel(file);
    return new Result(list);    //Result是一個(gè)專(zhuān)門(mén)返回參數(shù)的靜態(tài)類(lèi)
}

1.5 ServiceIMPL層解析Excel文件并將解析結(jié)果返回

解析結(jié)果后也可以自行做數(shù)據(jù)處理,我就直接將解析結(jié)果返回了

@Autowired
private Tools tools;	//工具類(lèi),上邊的兩個(gè)解析Excel文件的方法就在工具類(lèi)中

public List<Map<String,String>> uploadExcel(MultipartFile file){
	Workbook workbook = tools.getWorkbook(file);
	String[] colNames = {"","","","","","",};	//表格從第一列開(kāi)始的每一列列名,這個(gè)參數(shù)會(huì)作為map的key值,不可重復(fù)!??!
	List<Map<String,String>> list = tools.getExcelValues(file,colNames,1)	//這里具體的參數(shù)請(qǐng)看1.3解析部分方法前的注釋
	//這里可以根據(jù)業(yè)務(wù)增加對(duì)解析結(jié)果的數(shù)據(jù)處理,包括篩選、比對(duì)、入庫(kù)等操作
	return list;
}

1.6 前端VUE實(shí)現(xiàn)Excel文件的上傳(使用Element-ui的<el-upload>組件)

html部分

<template>
    <div>
        <el-upload 
        :method="method"
        :action="action"
        :multiple="multiple"
        :accept="accept"
        :auot-upload="auotUpload"
        :on-success="success"
        >
        </el-upload>
    </div>
</template>

JavaScript部分

    data(){
        return{
            method="post"     //請(qǐng)求方式
            action=""         //請(qǐng)求地址
            multiple="false"     //是否允許選擇多個(gè)文件
            accept="xls,xlsx"         //可以使用的文件類(lèi)型
            auotUpload="true"     //是否在選擇文件后自動(dòng)上傳文件
        }
    },
    method(){
        success(result){
            //這里是上傳組件上傳成功的回調(diào)函數(shù),result則是后臺(tái)的返回值,可以根據(jù)業(yè)務(wù)做數(shù)據(jù)處理
        }
    }

總結(jié)

到此這篇關(guān)于java解析Excel文件的方法的文章就介紹到這了,更多相關(guān)java解析Excel文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java中的Map允許有重復(fù)元素嗎?

    Java中的Map允許有重復(fù)元素嗎?

    今天小編就為大家分享一篇關(guān)于Java中的Map允許有重復(fù)元素嗎?,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-02-02
  • Java?OkHttp框架源碼超詳細(xì)解析

    Java?OkHttp框架源碼超詳細(xì)解析

    okhttp是一個(gè)第三方類(lèi)庫(kù),用于android中請(qǐng)求網(wǎng)絡(luò)。這是一個(gè)開(kāi)源項(xiàng)目,是安卓端最火熱的輕量級(jí)框架,由移動(dòng)支付Square公司貢獻(xiàn)(該公司還貢獻(xiàn)了Picasso和LeakCanary)?。用于替代HttpUrlConnection和Apache?HttpClient
    2022-11-11
  • 如何基于Autowired對(duì)構(gòu)造函數(shù)進(jìn)行注釋

    如何基于Autowired對(duì)構(gòu)造函數(shù)進(jìn)行注釋

    這篇文章主要介紹了如何基于Autowired對(duì)構(gòu)造函數(shù)進(jìn)行注釋,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • Java算法之桶排序Bucket?Sort詳解

    Java算法之桶排序Bucket?Sort詳解

    這篇文章主要介紹了Java算法之桶排序Bucket?Sort詳解,桶排序(Bucket?Sort)又稱(chēng)箱排序,是一種比較常用的排序算法,其算法原理是將數(shù)組分到有限數(shù)量的桶里,再對(duì)每個(gè)桶分別排好序,最后一次將每個(gè)桶中排好序的數(shù)輸出,需要的朋友可以參考下
    2023-10-10
  • Spring?Boot統(tǒng)一處理全局異常的實(shí)戰(zhàn)教程

    Spring?Boot統(tǒng)一處理全局異常的實(shí)戰(zhàn)教程

    最近在做項(xiàng)目時(shí)需要對(duì)異常進(jìn)行全局統(tǒng)一處理,所以下面這篇文章主要給大家介紹了關(guān)于Spring?Boot統(tǒng)一處理全局異常的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-12-12
  • 解決mybatis-plus使用jdk8的LocalDateTime 查詢(xún)時(shí)報(bào)錯(cuò)的方法

    解決mybatis-plus使用jdk8的LocalDateTime 查詢(xún)時(shí)報(bào)錯(cuò)的方法

    這篇文章主要介紹了解決mybatis-plus使用jdk8的LocalDateTime 查詢(xún)時(shí)報(bào)錯(cuò)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • java累加和校驗(yàn)實(shí)現(xiàn)方式16進(jìn)制(推薦)

    java累加和校驗(yàn)實(shí)現(xiàn)方式16進(jìn)制(推薦)

    下面小編就為大家?guī)?lái)一篇java累加和校驗(yàn)實(shí)現(xiàn)方式16進(jìn)制(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11
  • 使用Feign動(dòng)態(tài)設(shè)置header和原理分析

    使用Feign動(dòng)態(tài)設(shè)置header和原理分析

    這篇文章主要介紹了使用Feign動(dòng)態(tài)設(shè)置header和原理分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • java書(shū)店系統(tǒng)畢業(yè)設(shè)計(jì) 用戶(hù)模塊(2)

    java書(shū)店系統(tǒng)畢業(yè)設(shè)計(jì) 用戶(hù)模塊(2)

    這篇文章主要介紹了java書(shū)店系統(tǒng)畢業(yè)設(shè)計(jì),第二步系統(tǒng)總體設(shè)計(jì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • Java字符串技巧之刪除標(biāo)點(diǎn)或最后字符的方法

    Java字符串技巧之刪除標(biāo)點(diǎn)或最后字符的方法

    這篇文章主要介紹了Java字符串技巧之刪除標(biāo)點(diǎn)或最后字符的方法,是Java入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-11-11

最新評(píng)論