<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 一键上传到数据库的更多相关文章

  1. 一个简单的excel文件上传到数据库方法

    因为以前项目中有用到过Excel导入,所以整理了一下,这是一个导入Excel数据到数据库的方法 注意:需要导入poi jar包 代码清单 /** * Excel 导入 * @param mapping ...

  2. 使用ocupload和POI一键上传Excel并解析导入数据库

    使用的工具如下:  JQuery ocupload jquery.ocupload-1.1.2.js Apache POI poi-3.9.jar 如果是Maven项目添加依赖如下: <depe ...

  3. 文件一键上传、汉字转拼音、excel文件上传下载功能模块的实现

    ----------------------------------------------------------------------------------------------[版权申明: ...

  4. IT轮子系列(六)——Excel上传与解析,一套代码解决所有Excel业务上传,你Get到了吗

    前言 在日常开发当中,excel的上传与解析是很常见的.根据业务不同,解析的数据模型也都不一样.不同的数据模型也就需要不同的校验逻辑,这往往需要写多套的代码进行字段的检验,如必填项,数据格式.为了避免 ...

  5. Python 一键上传下载&一键提交文件到SVN入基线工具

    一键上传下载&一键提交文件到SVN入基线工具   by:授客 QQ:1033553122 实现功能 1 测试环境 1 使用说明 1   注: 根据我司项目规则订制的一套工具,集成以下功能,源码 ...

  6. HTML中简单实现文件的一键上传的操作

    在html中实现文件上传的方式为form表单中使用input type="file"控件,但是这个控件往往显示不是美观,影响页面效果,这时候,一般就通过一键上传的操作,来实现点击一 ...

  7. jQuery OCUpload ——> 一键上传插件

    OCUpload为jQuery的插件(One Click Upload),意思为一键上传,封装了对于文件上传的一些方法,只需几行代码,文件上传优雅而简洁.      对于传统的文件上传,只是通过inp ...

  8. [SAP ABAP开发技术总结]客户端文本文件、Excel文件上传下载

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  9. [SAP ABAP开发技术总结]文本文件、Excel文件上传下传

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

随机推荐

  1. Elasticsearch重要配置

    虽然Elasticsearch需要很少的配置,但是有一些设置需要手动配置,并且必须在进入生产之前进行配置. path.data  and path.logs cluster.name node.nam ...

  2. eclipse tomcat add时提示The Tomcat server configuration at \Servers\Tomcat v6.0 Server at localhost-

    原因为左侧项目中把对于网络应用的servers项目给关闭或删除了,导致相应的localhost-config无法定位,所以才发生的错误. 解决办法:删除servers下的tomcat 重新添加serv ...

  3. Navicat连接报错:cannot load OCI DLL,126

    32位系统下报错:cannot load OCI DLL,126 解决方法:navicat 菜单中 -工具->选项->OCI 选择oracle安装目录下bin里面的oci.dll 在win ...

  4. 深入理解 JavaScript 事件循环(一)— event loop

    引言 相信所有学过 JavaScript 都知道它是一门单线程的语言,这也就意味着 JS 无法进行多线程编程,但是 JS 当中却有着无处不在的异步概念 .在初期许多人会把异步理解成类似多线程的编程模式 ...

  5. Why you should QC your reads AND your assembly?

    鲤鱼基因组:http://www.ntv.cn/a/20140923/52953.shtml   关于鲤鱼基因组的测定,数据质量控制遭到质疑. Why you should QC your reads ...

  6. 初步探究java中程序退出、GC垃圾回收时,socket tcp连接的行为

    初步探究java中程序退出.GC垃圾回收时,socket tcp连接的行为 今天在项目开发中需要用到socket tcp连接相关(作为tcp客户端),在思考中发觉需要理清socket主动.被动关闭时发 ...

  7. 深入理解PHP对象注入

    0x00 背景 php对象注入是一个非常常见的漏洞,这个类型的漏洞虽然有些难以利用,但仍旧非常危险,为了理解这个漏洞,请读者具备基础的php知识. 0x01 漏洞案例 如果你觉得这是个渣渣洞,那么请看 ...

  8. 关于EasyUI中的Tree

    2017年6月21日,天气阴.心情比较沉重. 近期由于毕设的事情,三周不写代码了.这周测试提交了一些BUG,于是开始着手处理,还真的是熟能生巧,三周的功夫就感觉有点生疏.其中有一个BUG就是角色对应的 ...

  9. Treasure Hunt

    Treasure Hunt time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  10. 【CC2530入门教程-03】CC2530的中断系统及外部中断应用

    第3课  CC2530的中断系统及外部中断应用 广东职业技术学院  欧浩源 一.中断相关的基础概念  内核与外设之间的主要交互方式有两种:轮询和中断. 轮询的方式貌似公平,但实际工作效率很低,且不能及 ...