java解析Excel文件的方法實(shí)例詳解
在做一個(gè)項(xiàng)目時(shí),有很多原本保存在Excel文件中的基礎(chǔ)數(shù)據(jù),如此則需要一個(gè)Excel文件解析并獲取數(shù)據(jù),轉(zhuǎn)存至數(shù)據(jù)庫(kù)的功能,話不多說(shuō),上代碼
介紹
使用org.apache.poi依賴,我自己寫(xiě)了兩個(gè)類來(lái)實(shí)現(xiàn)對(duì)Excel文件的解析,重要的寫(xiě)前邊,后邊附加Controller與前端Element-ui的標(biāo)簽實(shí)現(xiàn)的文件上傳與接收
1.1 pom依賴
沒(méi)啥可說(shuō)的吧,加到pom文件中刷新maven依賴即可
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>自行選擇依賴版本</version>
< !-- 可用版本:4.1.2 --->
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-scratchpad</artifactId>
<version>自行選擇依賴版本</version>
< !-- 可用版本:4.1.2 --->
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>自行選擇依賴版本</version>
< !-- 可用版本:4.1.2 --->
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml-schemas</artifactId>
<version>自行選擇依賴版本</version>
< !-- 可用版本:4.1.2 --->
</dependency>
1.2 將數(shù)據(jù)流轉(zhuǎn)化為可解析的Workbook類型文件
/**
* 將EXCEL文件轉(zhuǎn)化為java可操作的Workbook類型
* @param file Excel文件的流對(duì)象
* @return Workbook workbook java可以操縱的文件類型
*/
public Workbook getWorkbook(MultipartFile file){
//獲取文件類型,即文件名后綴,通過(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ù)以List<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è)專門(mén)返回參數(shù)的靜態(tài)類
}
1.5 ServiceIMPL層解析Excel文件并將解析結(jié)果返回
解析結(jié)果后也可以自行做數(shù)據(jù)處理,我就直接將解析結(jié)果返回了
@Autowired
private Tools tools; //工具類,上邊的兩個(gè)解析Excel文件的方法就在工具類中
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" //可以使用的文件類型
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)文章
深入了解Spring中g(shù)etBean()的五種方式
在本文中,我們將詳細(xì)介紹從BeanFactory中獲取bean的多種方式。簡(jiǎn)單地說(shuō),正如方法的名稱所表達(dá)的,getBean()負(fù)責(zé)從Spring?IOC容器中獲取bean實(shí)例,希望對(duì)大家有所幫助2023-02-02
Java中Set集合轉(zhuǎn)為L(zhǎng)ist集合常見(jiàn)的兩種方式
List是Java中比較常用的集合類,指一系列存儲(chǔ)數(shù)據(jù)的接口和類,可以解決復(fù)雜的數(shù)據(jù)存儲(chǔ)問(wèn)題,這篇文章主要給大家介紹了關(guān)于Java中Set集合轉(zhuǎn)為L(zhǎng)ist集合常見(jiàn)的兩種方式,需要的朋友可以參考下2023-12-12
springboot 接口返回字符串帶引號(hào)的問(wèn)題解決
本文主要介紹了springboot 接口返回字符串帶引號(hào)的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
java中以DES的方式實(shí)現(xiàn)對(duì)稱加密并提供密鑰的實(shí)例
這篇文章主要介紹了java中以DES的方式實(shí)現(xiàn)對(duì)稱加密并提供密鑰的實(shí)例的相關(guān)資料,這里提供實(shí)例幫助大家學(xué)習(xí)理解這部分知識(shí),需要的朋友可以參考下2017-08-08
在SpringBoot中集成H2數(shù)據(jù)庫(kù)的完整指南
Spring Boot是一個(gè)簡(jiǎn)化企業(yè)級(jí)Java應(yīng)用程序開(kāi)發(fā)的強(qiáng)大框架,H2數(shù)據(jù)庫(kù)是一個(gè)輕量級(jí)的、開(kāi)源的SQL數(shù)據(jù)庫(kù),非常適合用于開(kāi)發(fā)和測(cè)試,本文將指導(dǎo)您如何在Spring Boot應(yīng)用程序中集成H2數(shù)據(jù)庫(kù),并探索一些高級(jí)配置選項(xiàng),需要的朋友可以參考下2024-10-10
SpringBoot使用EmbeddedDatabaseBuilder進(jìn)行數(shù)據(jù)庫(kù)集成測(cè)試
在開(kāi)發(fā)SpringBoot應(yīng)用程序時(shí),我們通常需要與數(shù)據(jù)庫(kù)進(jìn)行交互,為了確保我們的應(yīng)用程序在生產(chǎn)環(huán)境中可以正常工作,我們需要進(jìn)行數(shù)據(jù)庫(kù)集成測(cè)試,在本文中,我們將介紹如何使用 SpringBoot 中的 EmbeddedDatabaseBuilder 來(lái)進(jìn)行數(shù)據(jù)庫(kù)集成測(cè)試2023-07-07

