java解析Excel文件的方法實例詳解
在做一個項目時,有很多原本保存在Excel文件中的基礎(chǔ)數(shù)據(jù),如此則需要一個Excel文件解析并獲取數(shù)據(jù),轉(zhuǎn)存至數(shù)據(jù)庫的功能,話不多說,上代碼
介紹
使用org.apache.poi依賴,我自己寫了兩個類來實現(xiàn)對Excel文件的解析,重要的寫前邊,后邊附加Controller與前端Element-ui的標(biāo)簽實現(xiàn)的文件上傳與接收
1.1 pom依賴
沒啥可說的吧,加到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文件的流對象 * @return Workbook workbook java可以操縱的文件類型 */ public Workbook getWorkbook(MultipartFile file){ //獲取文件類型,即文件名后綴,通過獲取文件名并用.分割文件名,并取用返回值的第二個下標(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>>的格式返回數(shù)據(jù),每一個map代表一行數(shù)據(jù) * @Param workbook 需要操作的Excel文件 * @Param colNames 列名數(shù)組,需要該Excel表的每一列所對應(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<>(); //用于存儲最終結(jié)果 Map<String,String> map = new HashMap<>(); //用于逐一存儲表格的每一行數(shù)據(jù) Sheet sheet = workbook.getSgeetAt(SheetNum); //獲取Excel文件的表格 int rowNum = sheet.getPhysicalNumberOfRows(); //獲取當(dāng)前表格最大行數(shù) //循環(huán)遍歷表格的每一行,獲取每一行的值(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行的每一個單元格的值(j的初始值決定從表格的第幾列開始) for(int j = 0 ; j < colNames.length ; j ++){ try{ //這里可能會報錯,try{}catch{}一下 cellData = (String)row.getCell(j).getStringCellValue(); }catch(Exception e){ try{ //如果某一個單元格為純數(shù)字的字符串時會報錯,需特殊處理 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個單元格數(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是一個專門返回參數(shù)的靜態(tài)類 }
1.5 ServiceIMPL層解析Excel文件并將解析結(jié)果返回
解析結(jié)果后也可以自行做數(shù)據(jù)處理,我就直接將解析結(jié)果返回了
@Autowired private Tools tools; //工具類,上邊的兩個解析Excel文件的方法就在工具類中 public List<Map<String,String>> uploadExcel(MultipartFile file){ Workbook workbook = tools.getWorkbook(file); String[] colNames = {"","","","","","",}; //表格從第一列開始的每一列列名,這個參數(shù)會作為map的key值,不可重復(fù)?。?! List<Map<String,String>> list = tools.getExcelValues(file,colNames,1) //這里具體的參數(shù)請看1.3解析部分方法前的注釋 //這里可以根據(jù)業(yè)務(wù)增加對解析結(jié)果的數(shù)據(jù)處理,包括篩選、比對、入庫等操作 return list; }
1.6 前端VUE實現(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" //請求方式 action="" //請求地址 multiple="false" //是否允許選擇多個文件 accept="xls,xlsx" //可以使用的文件類型 auotUpload="true" //是否在選擇文件后自動上傳文件 } }, method(){ success(result){ //這里是上傳組件上傳成功的回調(diào)函數(shù),result則是后臺的返回值,可以根據(jù)業(yè)務(wù)做數(shù)據(jù)處理 } }
總結(jié)
到此這篇關(guān)于java解析Excel文件的方法的文章就介紹到這了,更多相關(guān)java解析Excel文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何基于Autowired對構(gòu)造函數(shù)進(jìn)行注釋
這篇文章主要介紹了如何基于Autowired對構(gòu)造函數(shù)進(jìn)行注釋,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-10-10Spring?Boot統(tǒng)一處理全局異常的實戰(zhàn)教程
最近在做項目時需要對異常進(jìn)行全局統(tǒng)一處理,所以下面這篇文章主要給大家介紹了關(guān)于Spring?Boot統(tǒng)一處理全局異常的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-12-12解決mybatis-plus使用jdk8的LocalDateTime 查詢時報錯的方法
這篇文章主要介紹了解決mybatis-plus使用jdk8的LocalDateTime 查詢時報錯的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08java累加和校驗實現(xiàn)方式16進(jìn)制(推薦)
下面小編就為大家?guī)硪黄猨ava累加和校驗實現(xiàn)方式16進(jìn)制(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11使用Feign動態(tài)設(shè)置header和原理分析
這篇文章主要介紹了使用Feign動態(tài)設(shè)置header和原理分析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03java書店系統(tǒng)畢業(yè)設(shè)計 用戶模塊(2)
這篇文章主要介紹了java書店系統(tǒng)畢業(yè)設(shè)計,第二步系統(tǒng)總體設(shè)計,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10