电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

Java實(shí)現(xiàn)Excel批量導(dǎo)入數(shù)據(jù)

瀏覽:165日期:2022-05-26 17:34:53

Excel的批量導(dǎo)入是很常見的功能,這里采用Jxl實(shí)現(xiàn),數(shù)據(jù)量或樣式要求較高可以采用 poi

框架環(huán)境:Spring + SpringMvc(注解實(shí)現(xiàn))

1.首先導(dǎo)入依賴jar包

<dependency> <groupId>net.sourceforge.jexcelapi</groupId> <artifactId>jxl</artifactId> <version>2.6.10</version></dependency>

2.前端頁(yè)面?jsp(enctype必須為'multipart/form-data' )

<%@ taglib prefix='c' uri='http://java.sun.com/jsp/jstl/core' %><%@ page contentType='text/html;charset=UTF-8' language='java' %><div style='width: 600px;'> <form method='post' data-submit='ajax' enctype='multipart/form-data' action='/hpersonnel/import.do'> //<input type='hidden' name='id' value='<%= request.getParameter('id') %>' /> <div class='form-group'> <label class='form-label w100'> </label> <label class='form-label '>1、下載模板。 <a href='http://www.hdgsjgj.cn/template/personnel.xls' rel='external nofollow' >下載</a> </label> </div> <div class='form-group'> <label class='form-label w100'> </label> <label class='form-label '>2、按照模板表頭填寫內(nèi)容,請(qǐng)勿修改文件格式</label> </div> <div class='form-group'> <label class='form-label w100'> </label> <label class='form-label '>3、<input type='file' name='file' /></label> </div> <div class='btns dialog-button'> <button type='submit'>提交</button> <button type='button' onclick='app.closeDialog(this)'>取消</button> </div> </form></div>

3.視圖模板

Java實(shí)現(xiàn)Excel批量導(dǎo)入數(shù)據(jù)

4.Controller

@ResponseBody@RequestMapping(value = 'import')public Object import(MultipartFile file) { if (file.isEmpty()) { return ResultObject.failure('文件為空'); } ResultObject result = new ResultObject(); //記錄集合 List<Map> mapList = new ArrayList<Map>(); //校驗(yàn)結(jié)果 boolean reqFlag = true; //回復(fù)消息 String reqMsg = ''; //報(bào)錯(cuò)消息數(shù) Integer error = 0; //解析文件 try { //轉(zhuǎn)換成輸入流 InputStream is = file.getInputStream(); //得到excel Workbook workbook = Workbook.getWorkbook(is); //得到sheet Sheet sheet = workbook.getSheet(0); //得到列數(shù) int colsNum = sheet.getColumns(); //得到行數(shù) int rowsNum = sheet.getRows(); if (rowsNum == 1) return ResultObject.failure('沒有數(shù)據(jù)'); //單元格 Cell cell; //數(shù)據(jù)校驗(yàn) for (int i = 1; i < rowsNum; i++) {//第一行是標(biāo)題,所以i從1開始 Map<Integer, Object> map = new HashMap<Integer, Object>(); for (int j = 0; j < colsNum; j++) { cell = sheet.getCell(j, i);//第一個(gè)參數(shù)是列.第二個(gè)參數(shù)是行 if (j < 4 && ''.equals(cell.getContents())) { //----這里判斷必填項(xiàng)(前4列) reqFlag = false; reqMsg += '第' + (i + 1) + '行錯(cuò)誤,錯(cuò)誤信息:' + '必填項(xiàng)缺漏'; reqMsg += '<br>'; error++; break; } String cellString = cell.getContents(); cellString = cellString.trim(); switch (j) { case 1: { //進(jìn)行校驗(yàn)處理,例如手機(jī)號(hào) if (!StringUtil.isMobileNo(cellString)) { reqFlag = false; reqMsg += '第' + (i + 1) + '行錯(cuò)誤,錯(cuò)誤信息:' + '聯(lián)系電話有誤'; reqMsg += '<br>'; error++; } else { map.put(j, cellString); } break; } case 2: { ### break; } case 3: { ### break; } //無(wú)需校驗(yàn),歸入default default: { map.put(j, cell.getContents()); } } } if (reqFlag) {//校驗(yàn)通過 mapList.add(map); } } } catch (IOException e) { e.printStackTrace(); } catch (BiffException e) { e.printStackTrace(); } //入庫(kù) try { if (mapList.size() > 0 && reqFlag) { //此處try,catch應(yīng)優(yōu)化為事務(wù)處理maplist實(shí)現(xiàn)全記錄成功或失敗 result.setSuccess('提交成功'); } else { if (error > 10) {//設(shè)置要顯示的錯(cuò)誤數(shù) int index = StringUtil.getIndex(reqMsg, 10, '<br>'); reqMsg = reqMsg.substring(0, index + 4); reqMsg += '未顯示錯(cuò)誤數(shù):' + (error - 10) + '條'; reqMsg += '<br>'; } result.setFailure(reqMsg); } } catch (Exception e) { result.setFailure('入庫(kù)錯(cuò)誤,請(qǐng)聯(lián)系管理員!'); e.printStackTrace(); } return result;}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: excel
相關(guān)文章:
主站蜘蛛池模板: 风电变桨伺服驱动器-风电偏航变桨系统-深圳众城卓越科技有限公司 | 样品瓶(色谱样品瓶)百科-浙江哈迈科技有限公司 | 学校用栓剂模,玻璃瓶轧盖钳,小型安瓿熔封机,实验室安瓿熔封机-长沙中亚制药设备有限公司 | 北钻固控设备|石油钻采设备-石油固控设备厂家 | 升降机-高空作业车租赁-蜘蛛车-曲臂式伸缩臂剪叉式液压升降平台-脚手架-【普雷斯特公司厂家】 | 北京浩云律师事务所-企业法律顾问_破产清算等公司法律服务 | 温控器生产厂家-提供温度开关/热保护器定制与批发-惠州市华恺威电子科技有限公司 | 通信天线厂家_室分八木天线_对数周期天线_天线加工厂_林创天线源头厂家 | 洁净化验室净化工程_成都实验室装修设计施工_四川华锐净化公司 | 大功率金属激光焊接机价格_不锈钢汽车配件|光纤自动激光焊接机设备-东莞市正信激光科技有限公司 定制奶茶纸杯_定制豆浆杯_广东纸杯厂_[绿保佳]一家专业生产纸杯碗的厂家 | 【法利莱住人集装箱厂家】—活动集装箱房,集装箱租赁_大品牌,更放心 | 坏男孩影院-提供最新电影_动漫_综艺_电视剧_迅雷免费电影最新观看 | 骁龙云呼电销防封号系统-axb电销平台-外呼稳定『免费试用』 | 健康管理师报名入口,2025年健康管理师考试时间信息网-网站首页 塑料造粒机「厂家直销」-莱州鑫瑞迪机械有限公司 | 液晶拼接屏厂家_拼接屏品牌_拼接屏价格_监控大屏—北京维康 | 鼓风干燥箱_真空烘箱_高温干燥箱_恒温培养箱-上海笃特科学仪器 | 柔软云母板-硬质-水位计云母片组件-首页-武汉长丰云母绝缘材料有限公司 | 粉末包装机,拆包机厂家,价格-上海强牛包装机械设备有限公司 | 多物理场仿真软件_电磁仿真软件_EDA多物理场仿真软件 - 裕兴木兰 | 不发火防静电金属骨料_无机磨石_水泥自流平_修补砂浆厂家「圣威特」 | 长江船运_国内海运_内贸船运_大件海运|运输_船舶运输价格_钢材船运_内河运输_风电甲板船_游艇运输_航运货代电话_上海交航船运 | 喷漆房_废气处理设备-湖北天地鑫环保设备有限公司 | 喷漆房_废气处理设备-湖北天地鑫环保设备有限公司 | 水稻烘干机,小麦烘干机,大豆烘干机,玉米烘干机,粮食烘干机_巩义市锦华粮食烘干机械制造有限公司 水环真空泵厂家,2bv真空泵,2be真空泵-淄博真空设备厂 | 语料库-提供经典范文,文案句子,常用文书,您的写作得力助手 | 真空粉体取样阀,电动楔式闸阀,电动针型阀-耐苛尔(上海)自动化仪表有限公司 | 石英粉,滑石粉厂家,山东滑石粉-莱州市向阳滑石粉有限公司 | 液压油缸-液压缸厂家价格,液压站系统-山东国立液压制造有限公司 液压油缸生产厂家-山东液压站-济南捷兴液压机电设备有限公司 | 苏州教学设备-化工教学设备-环境工程教学模型|同科教仪 | 专注提供国外机电设备及配件-工业控制领域一站式服务商-深圳市华联欧国际贸易有限公司 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 嘉兴恒升声级计-湖南衡仪声级计-杭州爱华多功能声级计-上海邦沃仪器设备有限公司 | 氧化锆纤维_1800度高温退火炉_1800度高温烧结炉-南京理工宇龙新材料股份有限公司 | 防勒索软件_数据防泄密_Trellix(原McAfee)核心代理商_Trellix(原Fireeye)售后-广州文智信息科技有限公司 | 恒压供水控制柜|无负压|一体化泵站控制柜|PLC远程调试|MCGS触摸屏|自动控制方案-联致自控设备 | 贴板式电磁阀-不锈钢-气动上展式放料阀-上海弗雷西阀门有限公司 工业机械三维动画制作 环保设备原理三维演示动画 自动化装配产线三维动画制作公司-南京燃动数字 | 深圳高新投三江工业消防解决方案提供厂家_服务商_园区智慧消防_储能消防解决方案服务商_高新投三江 | SPC工作站-连杆综合检具-表盘气动量仪-内孔缺陷检测仪-杭州朗多检测仪器有限公司 | 无线联网门锁|校园联网门锁|学校智能门锁|公租房智能门锁|保障房管理系统-KEENZY中科易安 | 产业规划_产业园区规划-产业投资选址及规划招商托管一体化服务商-中机院产业园区规划网 | 乙炔气体报警装置|固定式氯化氢检测仪|河南驰诚电气百科 |