Excel 一键上传到数据库
<a class="edit" id="batchImport"> 批量导入 </a>
js代码弹窗:
$("#batchImport").click(function(){
//弹窗弹窗下列内容
var html='<form id="execlForm" method="post" enctype="multipart/form-data">';
html+='<input type="file" name="file" id="execlFile" accept="application/vnd.ms-excel"/>';
html+='</form>';
layer.confirm(html, {
btn: ['导入','取消'] ,//按钮
title:'导入测试者'
}, function(){
var file = $("#execlFile").val();
console.info(file);
var strFileName=file.replace(/^.+?\\([^\\]+?)(\.[^\.\\]*?)?$/gi,"$1"); //正则表达式获取文件名,不带后缀
var fileName=file.replace(/.+\./,"");
if(fileName==''){
layer.msg('请选择上传文件!', {time:1000});
return false;
}
$.ajax({
url: '<%=path %>/front/conner/uploadExecl.do?',
type: 'POST',
cache: false,
data: new FormData($('#execlForm')[0]),
processData: false,
contentType: false
}).done(function(res) {
console.info(res);
if(res=="true"){
layer.msg('上传成功', {time:1000});
setTimeout(function(){
table.ajax.reload().draw();
},1500);
}else{
layer.msg('上传失败'+res+'条数据', {time:1000});
setTimeout(function(){
table.ajax.reload().draw();
},1500);
}
}).fail(function(res) {
//console.info(res);
});
});
});
controllor控制代码
/**
* 批量导入测试者信息
* @param request
* @param response
* @param bankName
*/
@RequestMapping("uploadExecl")
public void uploadBillFile(HttpServletRequest request, HttpServletResponse response){
// TODO 设置 咨询师编号 获取session里
Map map = sessionContext.get("frontUserInfo");
String counselorId = (String) map.get("ID");//获取咨询师的id
//list集合接收读取excel文件
List<MultipartFile> list = connerService.getMultipartFile(request);
if(list.size()==0){
out.out(response, "false");//表示未上传文件
}else{
String filename = list.get(0).getOriginalFilename();
//判断读取到的文件是否是excel格式
boolean flag = filename.endsWith(".xls");
if(flag){
try {
//判断正确则调用读取excel文件的函数
out.out(response, connerService.uploadBillFile(list.get(0),counselorId));
} catch (Exception e) {
e.printStackTrace();
out.out(response, "false");
}
}else{
out.out(response, "false");//上传的文件不是excel文件
}
}
}
//Service代码
/**
* 获取上传批量导入测试者信息
* @param request
* @return
*/
public List<MultipartFile> getMultipartFile(HttpServletRequest request) {
List<MultipartFile> list = new ArrayList<MultipartFile>();
CommonsMultipartResolver multipartResolver = new CommonsMultipartResolver(
request.getSession().getServletContext());
// 判断 request 是否有文件上传,即多部分请求
if (multipartResolver.isMultipart(request)) {
// 转换成多部分request
MultipartHttpServletRequest multiRequest = (MultipartHttpServletRequest) request;
// 取得request中的所有文件名
Iterator<String> iter = multiRequest.getFileNames();
while (iter.hasNext()) {
// 取得上传文件
MultipartFile file = multiRequest.getFile(iter.next());
list.add(file);
}
}
return list;
}
/**
* 读取excel文件的操作
* @param billFile
* @return
* @throws Exception
*/
public String uploadBillFile(MultipartFile billFile,String counselorId) throws Exception {
//创建集合
List<List> tolList = new ArrayList<List>();
InputStream is = billFile.getInputStream();
//读取excel文件的工作区域
jxl.Workbook workbook = jxl.Workbook.getWorkbook(is);
//设置只获取excel文件的第一个工作区
Sheet sheet = workbook.getSheet(0);
//获取行
int rows = sheet.getRows();
//获取列
int columns = sheet.getColumns();
//外循环获取行
for(int i = 1; i < rows; i++){
List eveList = new ArrayList<String>();
//定义布尔变量做标记
boolean flag=true;
//内循环列
for(int j = 0 ; j < 14 ;j++){
//cell是jxl里的类,在这里获取行和列
Cell cell = sheet.getCell(j, i);
String content = cell.getContents();
//StringUtils.isBlank判断某字符串是否为空或长度为0或由空白符
if(StringUtils.isBlank(content)){
flag=false;
//为假跳出
break;
}
//为真添加到集合
eveList.add(content);
}
//判断为true添加到集合
if(flag){
tolList.add(eveList);
}
}
//读取excel文件,如果有错误返回一个异常信息
List errorList = userInfoDao.saveBatchConner(tolList,counselorId) ;
String result = "true";
if(errorList.size() == 0){
}else{
result = ""+errorList.size();
}
return result;
}
Dao层代码
/**
* 咨询师操作批量保存测试者,上传excel操作
* 说明:函数主要读取excel文件,保存实体
* @param tolList
* @return
*/
public List saveBatchConner(List<List> toList,String counselorId) {
//学号,姓名,性别,出生日期,民族,血型,qq,邮箱,独生子女,单亲,所在地区,职业,学历,备注,咨询师验证。
List<UserInfo> errorList=new ArrayList<UserInfo>();
//提取execl列数据到属性集合,循环excel的内容
for(int i=0,len=toList.size();i<len;i++){
//获取excel tolList.get(获取一行).get(一行中的第一列).toString()
UserInfo userInfo = new UserInfo();
userInfo.setId(Uuid.getUuid());//获取不重复编号
userInfo.setCounselorId(counselorId);
userInfo.setIsConner("1");//1表示是测试者
userInfo.setAccount(toList.get(i).get(0).toString());//获取第一行第一列
userInfo.setUserName(toList.get(i).get(1).toString());//循环第一行第二列
userInfo.setSex(toList.get(i).get(2).toString());
userInfo.setBirthday(toList.get(i).get(3).toString());
userInfo.setNation(toList.get(i).get(4).toString());
userInfo.setBloodGroup(toList.get(i).get(5).toString());
userInfo.setQq(toList.get(i).get(6).toString());
userInfo.setEmail(toList.get(i).get(7).toString());
userInfo.setIsTheOnlyChild(toList.get(i).get(8).toString());//独生
userInfo.setIsSingleParent(toList.get(i).get(9).toString());//单亲
userInfo.setArea(toList.get(i).get(10).toString());//地区
userInfo.setProfession(toList.get(i).get(11).toString());//职业
userInfo.setEnducationlBackground(toList.get(i).get(12).toString());//学历
userInfo.setRemark(toList.get(i).get(13).toString());//备注
//保存到实体类
String flag=saveEntity(userInfo);
//如果有错误信息则返回一个集合
if(!"true".equals(flag)){
errorList.add(userInfo);
}
}
return errorList;
}
Excel 一键上传到数据库的更多相关文章
- 一个简单的excel文件上传到数据库方法
因为以前项目中有用到过Excel导入,所以整理了一下,这是一个导入Excel数据到数据库的方法 注意:需要导入poi jar包 代码清单 /** * Excel 导入 * @param mapping ...
- 使用ocupload和POI一键上传Excel并解析导入数据库
使用的工具如下: JQuery ocupload jquery.ocupload-1.1.2.js Apache POI poi-3.9.jar 如果是Maven项目添加依赖如下: <depe ...
- 文件一键上传、汉字转拼音、excel文件上传下载功能模块的实现
----------------------------------------------------------------------------------------------[版权申明: ...
- IT轮子系列(六)——Excel上传与解析,一套代码解决所有Excel业务上传,你Get到了吗
前言 在日常开发当中,excel的上传与解析是很常见的.根据业务不同,解析的数据模型也都不一样.不同的数据模型也就需要不同的校验逻辑,这往往需要写多套的代码进行字段的检验,如必填项,数据格式.为了避免 ...
- Python 一键上传下载&一键提交文件到SVN入基线工具
一键上传下载&一键提交文件到SVN入基线工具 by:授客 QQ:1033553122 实现功能 1 测试环境 1 使用说明 1 注: 根据我司项目规则订制的一套工具,集成以下功能,源码 ...
- HTML中简单实现文件的一键上传的操作
在html中实现文件上传的方式为form表单中使用input type="file"控件,但是这个控件往往显示不是美观,影响页面效果,这时候,一般就通过一键上传的操作,来实现点击一 ...
- jQuery OCUpload ——> 一键上传插件
OCUpload为jQuery的插件(One Click Upload),意思为一键上传,封装了对于文件上传的一些方法,只需几行代码,文件上传优雅而简洁. 对于传统的文件上传,只是通过inp ...
- [SAP ABAP开发技术总结]客户端文本文件、Excel文件上传下载
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- [SAP ABAP开发技术总结]文本文件、Excel文件上传下传
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
随机推荐
- ReactiveSwift源码解析(一) Event与Observer代码实现
ReactiveCocoa这个框架是做什么用的本篇博客就不做过多赘述了,什么是"响应式编程"也不多聊了,自行Google吧.本篇博客的主题是解析ReactiveCocoa框架中的核 ...
- SICP-Elements of program
编程语言=组合简单形成复杂的工具 简单的声明和表达式 简单元素之间的组合方式 组合后元素的抽象方式 程序=数据+函数 数据是我们要处理的内容 函数是我们处理数据的方式 函数式与中缀式 函数式不会出现歧 ...
- PHP设计模式:抽象工厂
示例代码详见https://github.com/52fhy/design_patterns 抽象工厂 抽象工厂(Abstract Factory)是应对产品族概念的.比如说,每个汽车公司可能要同时生 ...
- 【Android Developers Training】 63. 定义形状
注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...
- 【原创】无线破解Aircrack-ng套件详解--airmon-ng与airodump-ng
一:Aircrack-ng详解 1.1 Aircrack-ng概述 Aircrack-ng是一款用于破解无线802.11WEP及WPA-PSK加密的工具,该工具在2005年11月之前名字是Aircra ...
- [图形学] Chp14 GLU曲面裁剪函数程序示例及样条表示遗留问题
样条表示这章已经看完,最后的GLU曲面裁剪函数,打算按书中的示例实现一下,其中遇到了几个问题. 先介绍一下GLU曲面裁剪函数的使用方法. 1 裁剪函数是成对出现的: gluBeginTrim和gluE ...
- [SinGuLaRiTy] 组合数学题目复习
[SinGuLaRiTy] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. [CQBZOJ 2011] 计算系数 题目描述 给定一个多项式( ...
- mysql生成百万级数量测试数据
今天因为项目需要,想测试一下读取百万级数量数据的速度如何,无奈数据库没有现成符合要求的数据,网上百度一番有很都不错的文章,但是需要涉及到一些存储过程和用php代码什么的,虽说可以实现,但是感觉另外再弄 ...
- 使用 electron 做个播放器
使用 electron 做个播放器 本文同步更新在:https://github.com/whxaxes/blog/issues/8 前言 虽然 electron 已经出来好长时间了,但是最近才玩了一 ...
- 使用C#创建简单的WCF服务
一.开发环境 操作系统:Windows 10 开发环境:VS2015 编程语言:C# IIS版本:10.0.0.0 二.添加WCF服务.Internet Information Services(II ...