java 使用poi 導(dǎo)入Excel數(shù)據(jù)到數(shù)據(jù)庫(kù)的步驟
由于我個(gè)人電腦裝的Excel是2016版本的,所以這地方我使用了XSSF 方式導(dǎo)入 。
1 先手要制定一個(gè)Excel 模板 把模板放入javaWeb工程的某一個(gè)目錄下如圖:
2 模板建好了后,先實(shí)現(xiàn)模板下載功能 下面是頁(yè)面jsp代碼在這里只貼出部分代碼
<!-- excel 導(dǎo)入小模塊窗口 --> <div id="importBox" class="" style="display: none;"> <form id="importForm" action="<%=basePath%>book/dishes/backstageversion/list!importExcel" method="post" enctype="multipart/form-data" class="form-search" style="padding-left:20px;text-align:center;" onsubmit="loading('正在導(dǎo)入,請(qǐng)稍等...');"><br/> <input id="uploadFile" name="file" type="file" style="width:330px"/><br/><br/> <input id="btnImportSubmit" class="btn btn-primary" type="submit" value=" 導(dǎo) 入 "/> <input type="hidden" id="importCompanyId" name="importCompanyId" value=""/> <input type="hidden" id="importStallId" name="importStallId" value=""/> <a href="<%=basePath%>book/dishes/backstageversion/list!exportOrder" rel="external nofollow" rel="external nofollow" >下載模板</a> </form> </div>
<!-- excel 導(dǎo)入小模塊窗口 --> <div id="importBox" class="" style="display: none;"> <form id="importForm" action="<%=basePath%>book/dishes/backstageversion/list!importExcel" method="post" enctype="multipart/form-data" class="form-search" style="padding-left:20px;text-align:center;" onsubmit="loading('正在導(dǎo)入,請(qǐng)稍等...');"><br/> <input id="uploadFile" name="file" type="file" style="width:330px"/><br/><br/> <input id="btnImportSubmit" class="btn btn-primary" type="submit" value=" 導(dǎo) 入 "/> <input type="hidden" id="importCompanyId" name="importCompanyId" value=""/> <input type="hidden" id="importStallId" name="importStallId" value=""/> <a href="<%=basePath%>book/dishes/backstageversion/list!exportOrder" rel="external nofollow" rel="external nofollow" >下載模板</a> </form> </div>
下面是js
<!-- Bootstrap --> <link href="<%=path %>/res/admin/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet" type="text/css" /> <link href="<%=path %>/res/admin/css/xy_css.css" rel="external nofollow" rel="stylesheet" type="text/css"> <link href="<%=path %>/res/admin/css/font-awesome.min.css" rel="external nofollow" rel="stylesheet" type="text/css"> <script src="<%=path %>/res/admin/js/jquery.min.js"></script> <script src="<%=path %>/res/admin/js/bootstrap.min.js"></script> <link href="<%=path %>/res/admin/jquery-select2/3.4/select2.css" rel="external nofollow" rel="stylesheet" type="text/css" /> <script src="<%=path %>/res/admin/jquery-select2/3.4/select2.min.js"></script> <script src="<%=path %>/res/admin/jquery-select2/3.4/select2_locale_zh-CN.js"></script> <script type="text/javascript" src="<%=basePath%>res/admin/js/layer/layer.js"></script> <script type="text/javascript"> $(document).ready(function (){//加載頁(yè)面時(shí)執(zhí)行select2 $("select").select2(); //彈出導(dǎo)出窗口 $("#btnImport").click(function(){ var importStallId = $("#stallId option:selected").val(); var importCompanyId = $("#companyId option:selected").val(); $("#importCompanyId").val(importCompanyId); $("#importStallId").val(importStallId); if(importStallId==null || importStallId==""){ alert("請(qǐng)選擇檔口"); }else{ layer.open({ type: 1, skin: 'layui-layer-rim', //加上邊框 area: ['600px', '350px'], //寬高 content: $('#importBox') }); } }); });
3 下面是后臺(tái)代碼Action 類
一:下載模板代碼
/** * 下載模板 * @throws IOException */ public void exportOrder() throws IOException{ HttpServletRequest request = ServletActionContext.getRequest(); HttpServletResponse response = ServletActionContext.getResponse(); File file = null; InputStream inputStream = null; ServletOutputStream out = null; try { request.setCharacterEncoding("UTF-8"); String realPath = ServletActionContext.getServletContext().getRealPath("/"); file = new File(realPath+"WEB-INF/mailtemplate/dishes.xlsx"); inputStream = new FileInputStream(file); response.setCharacterEncoding("utf-8"); response.setContentType("application/msexcel"); response.setHeader("content-disposition", "attachment;filename=" + URLEncoder.encode("菜品導(dǎo)入" + ".xlsx", "UTF-8")); out = response.getOutputStream(); byte[] buffer = new byte[512]; // 緩沖區(qū) int bytesToRead = -1; // 通過(guò)循環(huán)將讀入的Excel文件的內(nèi)容輸出到瀏覽器中 while ((bytesToRead = inputStream.read(buffer)) != -1) { out.write(buffer, 0, bytesToRead); } out.flush(); } catch (Exception e) { e.printStackTrace(); } finally { if (inputStream != null) inputStream.close(); if (out != null) out.close(); if (file != null) file.delete(); // 刪除臨時(shí)文件 } }
二: 導(dǎo)入代碼
/** * 導(dǎo)入 * @throws IOException */ public void importExcel() throws IOException { List<Dishes> dishesList = getDishesList(file); if(dishesList !=null && dishesList.size()>0){ for(Dishes dishes : dishesList){ targetService.add(dishes); } } String basePath = ServletActionContext.getServletContext().getContextPath(); ServletActionContext.getResponse().sendRedirect(basePath + "/book/dishes/backstageversion/list"); } /** * 讀取Excel數(shù)據(jù) * @param filePath * @return List * @throws IOException */ private List<Dishes> getDishesList(String filePath) throws IOException { XSSFWorkbook workBook= null; InputStream is = new FileInputStream(filePath); try { workBook = new XSSFWorkbook(is); } catch (Exception e) { e.printStackTrace(); } Dishes dishes=null; List<Dishes> dishesList = new ArrayList<Dishes>(); //循環(huán)工作表sheet //List<XSSFPictureData> picturesList = getPicturesList(workBook);//獲取所有圖片 for(int numShett = 0;numShett<workBook.getNumberOfSheets();numShett++){ XSSFSheet sheet = workBook.getSheetAt(numShett); //調(diào)用獲取圖片 Map<String, PictureData> pictureDataMap = getPictureDataMap(sheet, workBook); if(sheet==null){ continue; } //循環(huán)Row for(int rowNum=1;rowNum<=sheet.getLastRowNum();rowNum++){ Row row = sheet.getRow(rowNum); if(row==null){ continue; } dishes = new Dishes(); //Cell Cell dishesName = row.getCell(0); if(dishesName==null){ continue; } dishes.setName(getValue(dishesName));//菜品名稱 Cell price = row.getCell(1); if(price==null){ continue; } dishes.setPrice(Double.parseDouble(getValue(price)));//優(yōu)惠價(jià)格 Cell oldPrice = row.getCell(2); if(oldPrice==null){ continue; } dishes.setOldPrice(Double.parseDouble(getValue(oldPrice)));//原價(jià)格 Cell summary = row.getCell(3); if(summary==null){ continue; } dishes.setSummary(getValue(summary));//菜品描述 Cell online = row.getCell(4); if(online==null){ continue; } dishes.setOnline(Integer.parseInt(getValue(online)));//是否上下架 Cell packCharge = row.getCell(5); if(packCharge==null){ continue; } dishes.setPackCharge(Double.parseDouble(getValue(packCharge)));//打包費(fèi) Cell stockNumber = row.getCell(6); if(stockNumber==null){//庫(kù)存為必填 continue; } dishes.setStockNumber(Integer.parseInt(getValue(stockNumber)));//每餐庫(kù)存 Cell immediateStock = row.getCell(7); if(immediateStock==null){//當(dāng)前庫(kù)存 continue; } dishes.setImmediateStock(Integer.parseInt(getValue(immediateStock)));//當(dāng)前庫(kù)存 Cell purchaseLimit = row.getCell(8); if(purchaseLimit==null){ continue; } dishes.setPurchaseLimit(Integer.parseInt(getValue(purchaseLimit)));//限購(gòu)數(shù)量 Cell restrictionType = row.getCell(9); if(restrictionType==null){ continue; } dishes.setRestrictionType(Integer.parseInt(getValue(restrictionType)));//限購(gòu)方式 Cell sort = row.getCell(10); if(sort==null){ continue; } dishes.setSort(Integer.parseInt(getValue(sort)));//排序 Cell contents = row.getCell(11); if(contents==null){ continue; } dishes.setContents(getValue(contents));//菜品詳情 dishes.setCreateTime(new Date()); Company company = companyService.load(importCompanyId); Stall stall = stallService.load(importStallId); dishes.setCompany(company); dishes.setStall(stall); //set 圖片 PictureData pictureData = pictureDataMap.get(rowNum+""); if(pictureData !=null){ String upImageUrl = UpImage(pictureData.getData()); dishes.setImage(upImageUrl); } dishesList.add(dishes); } } return dishesList; } /** * 得到Excel表中的值 * @param hssfCell * @return String */ @SuppressWarnings("unused") private String getValue(Cell cell){ DecimalFormat df = new DecimalFormat("###################.###########"); if(cell.getCellType()==cell.CELL_TYPE_BOOLEAN){ return String.valueOf(cell.getBooleanCellValue()); } if(cell.getCellType()==cell.CELL_TYPE_NUMERIC){ return String.valueOf(df.format(cell.getNumericCellValue())); }else{ return String.valueOf(cell.getStringCellValue()); } }
4 get set 方法
private String file; private Long importCompanyId; private Long importStallId;
public String getFile() { return file; } public void setFile(String file) { this.file = file; } public Long getImportCompanyId() { return importCompanyId; } public void setImportCompanyId(Long importCompanyId) { this.importCompanyId = importCompanyId; } public Long getImportStallId() { return importStallId; } public void setImportStallId(Long importStallId) { this.importStallId = importStallId; }
公司需求改變要增加導(dǎo)入圖片到又拍云服務(wù)器,所以下面增加讀取excel圖片
/** * 讀取Excel 中圖片 * @param sheet * @param workBook * @return */ private Map<String, PictureData> getPictureDataMap(XSSFSheet sheet,XSSFWorkbook workBook){ Map<String, PictureData> map = new HashMap<String,PictureData>(); for(POIXMLDocumentPart dr : sheet.getRelations()){ if(dr instanceof XSSFDrawing){ XSSFDrawing drawing = (XSSFDrawing) dr; List<XSSFShape> shapesList = drawing.getShapes(); if(shapesList !=null && shapesList.size()>0){ for(XSSFShape shape : shapesList){ XSSFPicture pic = (XSSFPicture) shape; XSSFClientAnchor anchor = pic.getPreferredSize(); CTMarker cTMarker = anchor.getFrom(); String picIndex = cTMarker.getRow()+""; map.put(picIndex, pic.getPictureData()); } } } } return map; }
/** * 上傳圖片到又拍云 * @param bytes * @return */ private String UpImage(byte[] bytes){ String fileName = UUID.randomUUID().toString() + ".jpg"; String uploadURL = UpYunClient.upload(fileName, bytes); return uploadURL; }
注意:請(qǐng)用Poi jar 3.9 版本 不然讀取圖片代碼會(huì)報(bào)錯(cuò)
以上就是java 使用poi 導(dǎo)入Excel 數(shù)據(jù)到數(shù)據(jù)庫(kù)的步驟的詳細(xì)內(nèi)容,更多關(guān)于Java 導(dǎo)入Excel 數(shù)據(jù)到數(shù)據(jù)庫(kù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java數(shù)據(jù)結(jié)構(gòu)之快速冪的實(shí)現(xiàn)
快速冪是用來(lái)解決求冪運(yùn)算的高效方式。本文將詳細(xì)為大家介紹如何利用Java實(shí)現(xiàn)快速冪,以及利用快速冪求解冪運(yùn)算問(wèn)題,需要的可以參考一下2022-03-03SpringBoot實(shí)現(xiàn)嵌入式 Servlet容器
傳統(tǒng)的Spring MVC工程部署時(shí)需要將WAR文件放置在servlet容器的文檔目錄內(nèi),而Spring Boot工程使用嵌入式servlet容器省去了這一步驟,本文就來(lái)設(shè)置一下相關(guān)配置,感興趣的可以了解一下2023-12-12Java發(fā)送form-data請(qǐng)求的實(shí)例代碼
在Java中發(fā)送form-data請(qǐng)求,可以使用Apache?HttpClient或OkHttp這樣的HTTP客戶端庫(kù)來(lái)發(fā)送請(qǐng)求,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-10-10解決Spring在Thread中注入Bean無(wú)效的問(wèn)題
這篇文章主要介紹了解決Spring在Thread中注入Bean無(wú)效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02java正則表達(dá)式學(xué)習(xí)筆記之命名捕獲
這篇文章主要為大家詳細(xì)介紹了java正則表達(dá)式中的命名捕獲,感興趣的小伙伴們可以參考一下2016-02-02Java8 Supplier接口和Consumer接口原理解析
這篇文章主要介紹了Java8 Supplier接口和Consumer接口原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04java -jar設(shè)置添加啟動(dòng)參數(shù)實(shí)現(xiàn)方法
這篇文章主要介紹了java -jar設(shè)置添加啟動(dòng)參數(shù)實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02