日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

java 使用poi 導(dǎo)入Excel數(shù)據(jù)到數(shù)據(jù)庫的步驟

瀏覽:190日期:2022-05-25 14:32:51

由于我個人電腦裝的Excel是2016版本的,所以這地方我使用了XSSF 方式導(dǎo)入 。

1 先手要制定一個Excel 模板 把模板放入javaWeb工程的某一個目錄下如圖:

java 使用poi 導(dǎo)入Excel數(shù)據(jù)到數(shù)據(jù)庫的步驟

2 模板建好了后,先實現(xiàn)模板下載功能 下面是頁面jsp代碼在這里只貼出部分代碼

<!-- excel 導(dǎo)入小模塊窗口 --><div class='' style='display: none;'> <form action='<%=basePath%>book/dishes/backstageversion/list!importExcel' method='post' enctype='multipart/form-data' onsubmit='loading(’正在導(dǎo)入,請稍等...’);'><br/> <input name='file' type='file' /><br/><br/> <input type='submit' value=' 導(dǎo) 入 '/> <input type='hidden' name='importCompanyId' value=''/> <input type='hidden' name='importStallId' value=''/> <a href='http://m.b3g6.com/bcjs/<%=basePath%>book/dishes/backstageversion/list!exportOrder' rel='external nofollow' rel='external nofollow' >下載模板</a> </form></div>

<!-- excel 導(dǎo)入小模塊窗口 --><div class='' style='display: none;'> <form action='<%=basePath%>book/dishes/backstageversion/list!importExcel' method='post' enctype='multipart/form-data' onsubmit='loading(’正在導(dǎo)入,請稍等...’);'><br/> <input name='file' type='file' /><br/><br/> <input type='submit' value=' 導(dǎo) 入 '/> <input type='hidden' name='importCompanyId' value=''/> <input type='hidden' name='importStallId' value=''/> <a href='http://m.b3g6.com/bcjs/<%=basePath%>book/dishes/backstageversion/list!exportOrder' rel='external nofollow' rel='external nofollow' >下載模板</a> </form></div>

下面是js

<!-- Bootstrap --> <link href='http://m.b3g6.com/bcjs/<%=path %>/res/admin/css/bootstrap.min.css' rel='external nofollow' rel='stylesheet' type='text/css' /> <link href='http://m.b3g6.com/bcjs/<%=path %>/res/admin/css/xy_css.css' rel='external nofollow' rel='stylesheet' type='text/css'> <link href='http://m.b3g6.com/bcjs/<%=path %>/res/admin/css/font-awesome.min.css' rel='external nofollow' rel='stylesheet' type='text/css'> <script src='http://m.b3g6.com/bcjs/<%=path %>/res/admin/js/jquery.min.js'></script> <script src='http://m.b3g6.com/bcjs/<%=path %>/res/admin/js/bootstrap.min.js'></script> <link href='http://m.b3g6.com/bcjs/<%=path %>/res/admin/jquery-select2/3.4/select2.css' rel='external nofollow' rel='stylesheet' type='text/css' /> <script src='http://m.b3g6.com/bcjs/<%=path %>/res/admin/jquery-select2/3.4/select2.min.js'></script> <script src='http://m.b3g6.com/bcjs/<%=path %>/res/admin/jquery-select2/3.4/select2_locale_zh-CN.js'></script> <script type='text/javascript' src='http://m.b3g6.com/bcjs/<%=basePath%>res/admin/js/layer/layer.js'></script> <script type='text/javascript'> $(document).ready(function (){//加載頁面時執(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('請選擇檔口'); }else{ layer.open({ type: 1, skin: ’layui-layer-rim’, //加上邊框 area: [’600px’, ’350px’], //寬高 content: $(’#importBox’) }); } }); });3 下面是后臺代碼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; // 通過循環(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(); // 刪除臨時文件 } }

二: 導(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)惠價格 Cell oldPrice = row.getCell(2); if(oldPrice==null){ continue; } dishes.setOldPrice(Double.parseDouble(getValue(oldPrice)));//原價格 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)));//打包費 Cell stockNumber = row.getCell(6); if(stockNumber==null){//庫存為必填 continue; } dishes.setStockNumber(Integer.parseInt(getValue(stockNumber)));//每餐庫存 Cell immediateStock = row.getCell(7); if(immediateStock==null){//當前庫存 continue; } dishes.setImmediateStock(Integer.parseInt(getValue(immediateStock)));//當前庫存 Cell purchaseLimit = row.getCell(8); if(purchaseLimit==null){ continue; } dishes.setPurchaseLimit(Integer.parseInt(getValue(purchaseLimit)));//限購數(shù)量 Cell restrictionType = row.getCell(9);if(restrictionType==null){ continue; } dishes.setRestrictionType(Integer.parseInt(getValue(restrictionType)));//限購方式 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; }

注意:請用Poi jar 3.9 版本 不然讀取圖片代碼會報錯

以上就是java 使用poi 導(dǎo)入Excel 數(shù)據(jù)到數(shù)據(jù)庫的步驟的詳細內(nèi)容,更多關(guān)于Java 導(dǎo)入Excel 數(shù)據(jù)到數(shù)據(jù)庫的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標簽: excel
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久久人人人| 日韩欧美字幕| 伊人精品在线| 亚洲一级特黄| 欧美综合另类| 激情欧美一区二区三区| 欧美日韩在线二区| 亚洲调教视频在线观看| 91超碰国产精品| 丝袜美腿一区二区三区| 在线看片一区| 日韩精品亚洲专区在线观看| 青草国产精品| 日本aⅴ免费视频一区二区三区| 亚洲乱亚洲高清| 日韩高清欧美激情| 国产精品主播| 国产精品久久久久久久久妇女| 欧美日韩免费看片| 亚洲精品小说| 亚洲午夜国产成人| 日本精品在线播放| 国产精品久久久久9999高清| 国内揄拍国内精品久久| 久久久天天操| 免费久久精品视频| 欧美日本久久| 91亚洲国产| 伊人久久大香线蕉av不卡| 亚洲美洲欧洲综合国产一区| 亚洲精品观看| 国产极品模特精品一二| 国产一区二区视频在线看| 欧洲在线一区| 蜜臀av性久久久久蜜臀aⅴ流畅| 日韩动漫一区| 天堂8中文在线最新版在线| 夜久久久久久| 国产精品日韩精品在线播放| 日本国产精品| 日韩精品一区二区三区中文| 国产videos久久| 亚洲欧美久久久| 国产情侣一区| 成人日韩在线| 日韩精品欧美精品| 黄在线观看免费网站ktv| 日韩视频一区| 免费视频一区二区三区在线观看| 欧美日韩精品一区二区视频| 欧美久久久网站| 成人羞羞在线观看网站| 欧美一区二区三区免费看| 韩国三级一区| 日韩二区在线观看| 日韩毛片在线| 国产欧美日韩在线一区二区| 久久精品国产99久久| 日韩美女国产精品| 日韩欧美一区二区三区在线观看| 亚洲精品欧美| 福利一区视频| 综合视频一区| 群体交乱之放荡娇妻一区二区| 日韩精品亚洲专区在线观看| 99久久精品国产亚洲精品| 国产精品2区| 免费看的黄色欧美网站| 久久久久久婷| 日本a级不卡| 自由日本语亚洲人高潮| 久久精品伊人| 日韩中文字幕| 国产尤物精品| 精品一区二区三区视频在线播放| 中文视频一区| 欧美一区三区| 精品久久福利| 欧美亚洲tv| 日本大胆欧美人术艺术动态| 日本不卡免费高清视频在线| 亚洲乱亚洲高清| 午夜国产一区二区| 97在线精品| 国产精品一区二区精品 | 国产伦理一区| 午夜精品影院| 超碰超碰人人人人精品| 欧美一区精品| 久久午夜精品| 久久免费大视频| 风间由美中文字幕在线看视频国产欧美| 亚洲免费毛片| 日韩中文欧美在线| 久久一区二区三区喷水| 日韩av在线播放网址| 国产日韩欧美一区二区三区| 天堂av在线一区| 欧美jjzz| 四虎影视精品| 久久青青视频| 老色鬼精品视频在线观看播放| 日韩精品视频网| 婷婷精品在线观看| 亚洲一区有码| 夜夜嗨网站十八久久 | 日韩高清一区二区| 中文视频一区| 久色成人在线| 欧美专区18| 中国女人久久久| 亚洲大全视频| 尹人成人综合网| 欧美日韩国产一区精品一区| 成人羞羞在线观看网站| 久草免费在线视频| 国产在线观看www| 激情视频网站在线播放色| 国产成人在线中文字幕| 丁香婷婷久久| 日韩成人a**站| 日韩国产专区| 久久久久.com| 激情综合在线| 亚洲欧洲午夜| 免费成人在线影院| 一区二区三区四区在线观看国产日韩| 久久夜色精品| 亚洲另类视频| 日韩精品三级| 国产日韩亚洲欧美精品| 国产精品久久久久久模特| 国产精品一区三区在线观看| 国产精品久一| a国产在线视频| 色在线视频观看| 久久视频精品| 免费日韩av片| 日本免费新一区视频| 国产精品久久久久久久久免费高清| 麻豆精品蜜桃视频网站| 福利精品在线| 亚洲午夜91| 亚洲一区欧美| 国产日韩中文在线中文字幕| 久久不卡日韩美女| 国产一区二区亚洲| 99久久婷婷这里只有精品| 亚洲黄色影院| 亚洲精品欧洲| 鲁大师精品99久久久| 亚洲风情在线资源| 免费国产自久久久久三四区久久 | 欧美另类专区| 亚洲精品精选| 久久中文字幕一区二区| 中文字幕成在线观看| 国产精品97| 中文字幕亚洲精品乱码| 久久国际精品| 成人福利av| 一区视频在线| 7m精品国产导航在线| 国产精品不卡| 一区免费视频| 国产欧美日韩一区二区三区在线| 精品国产一区二区三区噜噜噜| 91精品一区国产高清在线gif| 首页国产欧美久久| 国产精品对白| 91精品一区国产高清在线gif| 在线精品一区| 国产理论在线| 亚洲成人免费| 国产精品99久久免费| 伊人久久大香线蕉av不卡| 日本欧美韩国一区三区| 97精品中文字幕| 视频一区欧美精品| 久久97久久97精品免视看秋霞| 欧美一级精品| 国产毛片久久久| 99久久夜色精品国产亚洲1000部| 伊人精品久久| 国产精品qvod| 99视频精品免费观看| 国产高清日韩| 国产精品婷婷| 国产精品一线| aⅴ色国产欧美| 国产一区不卡| 日韩精品视频在线看| 久久精品国产亚洲夜色av网站| 欧美私人啪啪vps| 好看的av在线不卡观看| 精品国产一区二区三区av片| 亚洲伊人影院| 成人免费电影网址| 国产精品三p一区二区| 在线一区免费观看|