Java POI實(shí)現(xiàn)將導(dǎo)入Excel文件的示例代碼
問(wèn)題描述
現(xiàn)需要批量導(dǎo)入數(shù)據(jù),數(shù)據(jù)以Excel形式導(dǎo)入。
POI介紹
我選擇使用的是apache POI。這是有Apache軟件基金會(huì)開(kāi)放的函數(shù)庫(kù),他會(huì)提供API給java,使其可以對(duì)office文件進(jìn)行讀寫。
我這里只需要使用其中的Excel部分。
實(shí)現(xiàn)
首先,Excel有兩種格式,一種是.xls(03版),另一種是.xlsx(07版)。針對(duì)兩種不同的表格格式,POI對(duì)應(yīng)提供了兩種接口。HSSFWorkbook和XSSFWorkbook
導(dǎo)入依賴
<dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>RELEASE</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>RELEASE</version> </dependency>
處理版本
Workbook workbook = null; try { if (file.getPath().endsWith("xls")) { System.out.println("這是2003版本"); workbook = new XSSFWorkbook(new FileInputStream(file)); } else if (file.getPath().endsWith("xlsx")){ workbook = new HSSFWorkbook(new FileInputStream(file)); System.out.println("這是2007版本"); } } catch (IOException e) { e.printStackTrace(); }
這里需要判斷一下Excel的版本,根據(jù)擴(kuò)展名,用不同的類來(lái)處理文件。
獲取表格數(shù)據(jù)
獲取表格中的數(shù)據(jù)分為以下幾步:
1.獲取表格
2.獲取某一行
3.獲取這一行中的某個(gè)單元格
代碼實(shí)現(xiàn):
// 獲取第一個(gè)張表 Sheet sheet = workbook.getSheetAt(0); // 獲取每行中的字段 for (int i = 0; i <= sheet.getLastRowNum(); i++) { Row row = sheet.getRow(i); // 獲取行 // 獲取單元格中的值 String studentNum = row.getCell(0).getStringCellValue(); String name = row.getCell(1).getStringCellValue(); String phone = row.getCell(2).getStringCellValue(); }
持久化
獲取出單元格中的數(shù)據(jù)后,最后就是用數(shù)據(jù)建立對(duì)象了。
List<Student> studentList = new ArrayList<>(); for (int i = 0; i <= sheet.getLastRowNum(); i++) { Row row = sheet.getRow(i); // 獲取行 // 獲取單元格中的值 String studentNum = row.getCell(0).getStringCellValue(); String name = row.getCell(1).getStringCellValue(); String phone = row.getCell(2).getStringCellValue(); Student student = new Student(); student.setStudentNumber(studentNum); student.setName(name); student.setPhoneNumber(phone); studentList.add(student); } // 持久化 studentRepository.saveAll(studentList);
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java實(shí)現(xiàn)讀取文件夾下(包括子目錄)所有文件的文件名
這篇文章主要介紹了Java實(shí)現(xiàn)讀取文件夾下(包括子目錄)所有文件的文件名,本文把代碼組織成了一個(gè)模塊,可以很方便的使用,需要的朋友可以參考下2015-06-06使用FeignClient調(diào)用遠(yuǎn)程服務(wù)時(shí)整合本地的實(shí)現(xiàn)方法
這篇文章主要介紹了使用FeignClient調(diào)用遠(yuǎn)程服務(wù)時(shí)整合本地的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03Spring Security注冊(cè)過(guò)濾器注意事項(xiàng)詳解
前兩天和小伙伴聊了 Spring Security+JWT 實(shí)現(xiàn)無(wú)狀態(tài)登錄,然后有小伙伴反饋了一個(gè)問(wèn)題,感覺(jué)這是一個(gè)我們平時(shí)寫代碼容易忽略的問(wèn)題,所以本文給大家介紹了Spring Security注冊(cè)過(guò)濾器注意事項(xiàng),需要的朋友可以參考下2024-06-06JAVA設(shè)計(jì)模式之訪問(wèn)者模式詳解
這篇文章主要介紹了JAVA設(shè)計(jì)模式之訪問(wèn)者模式詳解,訪問(wèn)者模式是對(duì)象的行為模式,訪問(wèn)者模式的目的是封裝一些施加于某種數(shù)據(jù)結(jié)構(gòu)元素之上的操作,需要的朋友可以參考下2015-04-04JAVA 根據(jù)Url把多文件打包成ZIP下載實(shí)例
這篇文章主要介紹了JAVA 根據(jù)Url把多文件打包成ZIP下載的相關(guān)資料,需要的朋友可以參考下2017-08-08SPFA算法的實(shí)現(xiàn)原理及其應(yīng)用詳解
SPFA算法,全稱為Shortest?Path?Faster?Algorithm,是求解單源最短路徑問(wèn)題的一種常用算法,本文就來(lái)聊聊它的實(shí)現(xiàn)原理與簡(jiǎn)單應(yīng)用吧2023-05-05基于Eclipse 的JSP/Servlet的開(kāi)發(fā)環(huán)境的搭建(圖文)
本文將會(huì)詳細(xì)地展示如何搭建JSP的開(kāi)發(fā)環(huán)境。本次教程使用的是最新版的Eclipse 2018-09編輯器和最新版的Apache Tomcat v9.0,步驟詳細(xì),內(nèi)容詳盡,適合零基礎(chǔ)學(xué)者作為學(xué)習(xí)參考2018-12-12mybatis實(shí)現(xiàn)查詢操作及獲得添加的ID
這篇文章主要介紹了mybatis實(shí)現(xiàn)查詢操作及獲得添加的ID,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-11-11