摘要:背景小白今天閑著沒(méi)事,在公司摸魚(yú),以為今天有事無(wú)聊的一天,突然上頭說(shuō)小子,今天實(shí)現(xiàn)一下批量導(dǎo)入數(shù)據(jù)吧,當(dāng)時(shí)我的內(nèi)心是拒絕的,然后默默打開(kāi)。介紹框架本身并不支持讀取,所有讀取需要借助一些框架。
1 背景
小白今天閑著沒(méi)事,在公司摸魚(yú),以為今天有事無(wú)聊的一天,突然上頭說(shuō)小子,今天實(shí)現(xiàn)一下批量導(dǎo)入Excel數(shù)據(jù)吧,當(dāng)時(shí)我的內(nèi)心是拒絕的,然后默默打開(kāi)idea。
2 介紹 2.1 框架java本身并不支持讀取excel,所有讀取excel需要借助一些框架。目前有幾種方式,
1. Apache POI
2. Java Excel API
3. easyexcel
這里主要講解的是 Apache POI,Apache POI支持03版以及07年版 區(qū)別是后綴不一樣,03版對(duì)應(yīng)的是xls 07版對(duì)應(yīng)的是xlsx xlsx
這里主要講解的是07版的
1.sheet表示的是
excel底部的工作表.
對(duì)應(yīng)的是POI的的XSSFSheet
2.row表示的是行
對(duì)應(yīng)的是POI的的XSSFRow
3.cell表示的是每一行的單元格.
對(duì)應(yīng)的是POI的的Cell
3 源碼 3.0 片段說(shuō)明1.上傳文件使用springboot的MultipartFile
對(duì)應(yīng)
MultipartFile file
2.創(chuàng)建對(duì)象
XSSFWorkbook xssfWorkbook = new XSSFWorkbook(inputStream);
3.獲取sheet(默認(rèn)第一個(gè))
XSSFSheet sheet = xssfWorkbook.getSheetAt(0);3.1 控制層源碼
@RequestMapping("/import") public void importExcel(@RequestParam("file") MultipartFile file) throws Exception{ InputStream inputStream = file.getInputStream(); //07年的 不兼容之前 XSSFWorkbook xssfWorkbook = new XSSFWorkbook(inputStream); XSSFSheet sheet = xssfWorkbook.getSheetAt(0); //獲取行數(shù) int lastRowNum = sheet.getLastRowNum(); for (int i = 1; i <= lastRowNum; i++) { XSSFRow row = sheet.getRow(i); QuChannel quChannel = new QuChannel(); if (row.getCell(0) != null){ row.getCell(0).setCellType(XSSFCell.CELL_TYPE_STRING); quChannel.setChannel(row.getCell(0).getStringCellValue()); } if (row.getCell(1) != null){ row.getCell(1).setCellType(XSSFCell.CELL_TYPE_STRING); quChannel.setChannelName(row.getCell(1).getStringCellValue()); } if (row.getCell(2) != null){ row.getCell(2).setCellType(XSSFCell.CELL_TYPE_STRING); quChannel.setRemarks(row.getCell(2).getStringCellValue()); } if (row.getCell(3) != null){ quChannel.setChannelSource((int) row.getCell(3).getNumericCellValue()); } if (row.getCell(4) != null){ quChannel.setActivityType((int) row.getCell(4).getNumericCellValue()); } if (row.getCell(5) != null){ quChannel.setDeliveryTime(row.getCell(5).getDateCellValue()); } if (row.getCell(6) != null){ row.getCell(6).setCellType(XSSFCell.CELL_TYPE_STRING); quChannel.setOriginalLink(row.getCell(6).getStringCellValue()); } if (row.getCell(7) != null){ row.getCell(7).setCellType(XSSFCell.CELL_TYPE_STRING); quChannel.setSaLink(row.getCell(7).getStringCellValue()); } if (row.getCell(8) != null){ quChannel.setDeliveryMode((int) row.getCell(8).getNumericCellValue()); } if (row.getCell(9) != null){ quChannel.setCreateGroup((int) row.getCell(9).getNumericCellValue()); } if (row.getCell(10) != null){ row.getCell(10).setCellType(XSSFCell.CELL_TYPE_STRING); quChannel.setRemark(row.getCell(10).getStringCellValue()); } quChannelMapper.insert(quChannel); } }3.2 review
1.避免將sql寫(xiě)在for循環(huán)里面,改進(jìn)的話(huà)可以創(chuàng)建一個(gè)列表list,將對(duì)象add進(jìn)去,然后在循環(huán)外面進(jìn)行批量插入
2.想要去重的話(huà)可以使用set的不能重復(fù)添加特性
3.注意excel的字段與類(lèi)屬性的對(duì)應(yīng)關(guān)系,如果excel字段是string,但是累屬性是整形的話(huà),可以使用枚舉類(lèi)
暫時(shí)想到這么多 歡迎指教評(píng)論
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/74912.html
摘要:總結(jié)整個(gè)過(guò)程的難點(diǎn)在于獲取文件對(duì)象,從數(shù)據(jù)中取值然后在按取出,這樣我們就可以從后臺(tái)上傳文件,然后進(jìn)行批量導(dǎo)入數(shù)據(jù)庫(kù),其他數(shù)據(jù)格式只需要改和中的數(shù)據(jù)字段就可以 第一篇(從django后臺(tái)解析excel數(shù)據(jù)批量導(dǎo)入數(shù)據(jù)庫(kù)) 文章會(huì)在github中持續(xù)更新 作者: knthony github 聯(lián)系我 1.django 如何從后臺(tái)上傳excel中批量解析數(shù)據(jù) 要從django后臺(tái)導(dǎo)入...
摘要:批量導(dǎo)入數(shù)據(jù)庫(kù)思想之一頁(yè)面上傳表格后臺(tái)解析表格的數(shù)據(jù)暫放數(shù)據(jù)結(jié)構(gòu)中或自己看情況處理,再把里面的數(shù)據(jù)批量存入數(shù)據(jù)庫(kù)。 批量導(dǎo)入數(shù)據(jù)庫(kù)思想之一:頁(yè)面上傳excel表格后臺(tái)解析excel表格的數(shù)據(jù)暫放數(shù)據(jù)結(jié)構(gòu)中(list或Map,自己看情況處理),再把list里面的數(shù)據(jù)批量存入數(shù)據(jù)庫(kù)。直接貼代碼: 前端: 文件描述: ...
摘要:然后封面就一個(gè)一個(gè)下啦是不是很方便具體源代碼在上有用的話(huà)記得星星 有時(shí)候會(huì)有這樣的需求吧 有一個(gè)表格里面有一批數(shù)據(jù)需要批量生成封面我們?cè)跒g覽器里可以批量生成比如 showImg(https://segmentfault.com/img/bV67kB?w=2308&h=996); 我們有這樣一個(gè)表格需要生成圖書(shū)封面 showImg(https://segmentfault.com/img...
摘要:并且在對(duì)的抽象中,每一行,每一個(gè)單元格都是一個(gè)對(duì)象。對(duì)支持使用官方例子需要繼承,覆蓋方法,每讀取到一個(gè)單元格的數(shù)據(jù)則會(huì)回調(diào)次方法。概要Java對(duì)Excel的操作一般都是用POI,但是數(shù)據(jù)量大的話(huà)可能會(huì)導(dǎo)致頻繁的FGC或OOM,這篇文章跟大家說(shuō)下如果避免踩POI的坑,以及分別對(duì)于xls和xlsx文件怎么優(yōu)化大批量數(shù)據(jù)的導(dǎo)入和導(dǎo)出。一次線(xiàn)上問(wèn)題這是一次線(xiàn)上的問(wèn)題,因?yàn)橐粋€(gè)大數(shù)據(jù)量的Excel導(dǎo)出...
閱讀 1272·2021-09-02 13:36
閱讀 2727·2019-08-30 15:44
閱讀 2982·2019-08-29 15:04
閱讀 3200·2019-08-26 13:40
閱讀 3650·2019-08-26 13:37
閱讀 1181·2019-08-26 12:22
閱讀 1021·2019-08-26 11:36
閱讀 1223·2019-08-26 10:41