• JAVA实现Excel批量导入


    一、模板下载:

    先将模板放在项目WebRoot下的download文件夹下:

    /**
         * @Title: downloadFile 
         * @Description: 模板下载 (网络地址)
         * @param @param id 
         * @param @param url
         * @param @param fileName
         * @param @param response
         * @param @param request
         * @param @throws Exception
         * @return void
         * @throws
         */
        @RequestMapping(value = "/downloadFile")
        public void downloadFile(String url, String fileName, 
                HttpServletResponse response,HttpServletRequest request) throws Exception{
            
            //要对文件名称进行编码
            fileName = java.net.URLEncoder.encode(fileName,"utf-8");
            response.addHeader("Content-Disposition","attachment;filename=" + fileName+";filename*=utf-8''"+fileName);    
            response.setContentType("application/octet-stream"); //设置文件MIME类型  
            
            OutputStream out =null;
            InputStream  in=null;
            
            //获取网站部署路径(通过ServletContext对象),用于确定下载文件位置,从而实现下载  
            //String path = request.getServletContext().getRealPath("/"); 
            //url = path + "download\" + "我的客户导入模板.xls";
            
            try {
                
                URL urlPath = new URL(url);// 创建URL对象
                in = urlPath.openStream();// 获取url中的输入流
                out = response.getOutputStream();
                BufferedInputStream bis = new BufferedInputStream(in);
                BufferedOutputStream bos = new BufferedOutputStream(out);
                
                byte[] buff = new byte[20480];
                int b = 0;
                while (-1 != (b = bis.read(buff))) {
                    bos.write(buff, 0, b);
                }
                bis.close();
                bos.flush();
                bos.close();
            }catch(Exception e){
                e.printStackTrace();
            }
            
            finally {
                if(out!=null)out.close();
                if(in!=null)in.close();
            }
        }
    View Code
    /**
         * 
         * @Title: download 
         * @Description: 下载本地文件
         * @param @param path
         * @param @param response
         * @param @param request
         * @return void
         * @throws
         */
        @RequestMapping(value = "/download")
        public void download(String type, HttpServletResponse response, HttpServletRequest request) {
            
            User u = getUser(request.getSession());//SessionUtils.getUser(request.getSession());
            
            //获取网站部署路径(通过ServletContext对象),用于确定下载文件位置,从而实现下载  
            //path = request.getServletContext().getRealPath("/") + "download\" + "我的客户导入模板.xls";
            String path = request.getServletContext().getRealPath("/");  
            
            List<BasedataResp> list1 = null;
            List<BasedataResp> list2 = null;
            QueryBasedataParam param1 = new QueryBasedataParam();
            QueryBasedataParam param2 = new QueryBasedataParam();
            param1.setCorpId(Long.valueOf(u.getCorpId()));
            param2.setCorpId(Long.valueOf(u.getCorpId()));
            
            String fileName = "";
            if("1".equals(type)){
                
                fileName = "我的客户导入模板";
                param1.setLabel("custom_status"); //客户状态
                param2.setLabel("custom_level"); //客户分级
            } else if("2".equals(type)){
                
                fileName = "客户关联联系人导入模板";
                param1.setLabel("contacts_role"); //角色关系
                param2.setLabel("contacts_relation"); //亲密程度
            }
            String url = path + "download\" + fileName + ".xls";
            
            try {  
                
                if(param1.getLabel()!=null && !"".equals(param1.getLabel())){
                    list1 = basedataService.selectBasedataInfo(param1); //查询系统标签 
                    list2 = basedataService.selectBasedataInfo(param2); //查询系统标签 
                    write(url, list1, list2);
                }
                ExcelExportUtil.getExcel(url, fileName, response); //下载sheet
                
            } catch (Exception e) {  
                System.out.println(e.getMessage());
            }  
        }
        
        /**
         * 
         * @Title: write 
         * @Description: 向已存在的Excel写入数据 
         * @param @param file
         * @param @param list
         * @param @param list2
         * @param @return
         * @return String
         * @throws
         */
        private String write(String file, List<BasedataResp> list, List<BasedataResp> list2) {
            
            try {
                
                FileInputStream fs = new FileInputStream(file);  //获取已有的Excel  
                POIFSFileSystem ps = new POIFSFileSystem(fs);  //使用POI提供的方法得到excel的信息   
                HSSFWorkbook wb = new HSSFWorkbook(ps);    
                HSSFSheet sheet1 = wb.getSheetAt(0);  //获取第一个工作表,一个excel可能有多个工作表 
                HSSFSheet sheet2 = wb.getSheetAt(1); //获取第二个sheet
                HSSFSheet sheet3 = wb.getSheetAt(2); //获取第三个sheet
                
                sheet2.removeRow(sheet2.getRow(0));
                sheet3.removeRow(sheet3.getRow(0));
                
                FileOutputStream out = new FileOutputStream(file);  //向d://test.xls中写数据
                
                HSSFRow row;
           //向第二个sheet写入数据(第一个sheet中的下拉选项)
    for (int i = 0; i < list.size(); i++) { row = sheet2.createRow((short)(i)); //创建行 row.createCell(0).setCellValue(list.get(i).getName()); //设置第一个(从0开始)单元格的数据 }
           //向第三个sheet写入数据(第一个sheet中的下拉选项)  HSSFRow row2;
    for (int i = 0; i < list2.size(); i++) { row2 = sheet3.createRow((short)(i)); //创建行 row2.createCell(0).setCellValue(list2.get(i).getName()); //设置第一个(从0开始)单元格的数据 } out.flush(); wb.write(out); out.close(); } catch (Exception e) { System.out.println(e.getMessage()); } return "success"; }
    /**
         * 
         * @Title: getExcel 
         * @Description: 下载指定路径的Excel文件 
         * @param @param url 文件路径
         * @param @param fileName  文件名
         * @param @param response
         * @return void
         * @throws
         */
        public static void getExcel(String url, String fileName, HttpServletResponse response){
            
             try {  
                
                //1.设置文件ContentType类型,这样设置,会自动判断下载文件类型  
                response.setContentType("multipart/form-data");  
                
                //2.设置文件头:最后一个参数是设置下载文件名  
                response.setHeader("Content-Disposition", "attachment;filename="  
                        + new String(fileName.getBytes("gb2312"), "ISO-8859-1") + ".xls"); //支持中文文件名
                
                //通过文件路径获得File对象
                File file = new File(url);  
                
                FileInputStream in = new FileInputStream(file);  
                //3.通过response获取OutputStream对象(out)  
                OutputStream out = new BufferedOutputStream(response.getOutputStream());  
                
                int b = 0;  
                byte[] buffer = new byte[2048];  
                while ((b=in.read(buffer)) != -1){  
                    out.write(buffer,0,b); //4.写到输出流(out)中  
                }  
                
                in.close();
                out.flush(); 
                out.close();  
                
            } catch (IOException e) {  
                e.printStackTrace();  
            }  
        }
        

    模板截图:

    二、通过Excel模板导入数据:

        /**
         * 
         * @Title: impExcel 
         * @Description: 批量导入客户信息
         * @param @param request
         * @param @param response
         * @param @return
         * @return String
         * @throws
         */
        @RequestMapping("impExcel")
        @ResponseBody
        public String impExcel(MultipartHttpServletRequest request,HttpServletResponse response){
            
            ReturnStandardDataFormat standardData = new ReturnStandardDataFormat(CustomConstants.CUSTOM_SELECT_EXCEPTION,"导入客户信息失败",null);
            
            MultipartFile file = request.getFile("file");
            ExcelReader er = new ExcelReader();
            int count =0;
            int error =0;
            int success = 0;
            
            List<Custom> list_ = new ArrayList<Custom>();
            User u = getUser(request.getSession());//SessionUtils.getUser(request.getSession());
            Long corpId = Long.valueOf(u.getCorpId());
            Date date = new Date();
            String returnMsg = "";
            int index = 1;
            
            try {
                
                List<Map<Integer,String>> list = er.readExcelContentByList(file.getInputStream()); //读取Excel数据内容
                count = list.size();
                
                for(Map<Integer,String> map : list){
                    
                    if(map.get(0)==null || "".equals(map.get(0))){
                        returnMsg += "第"+index+"行:【客户简称(必填)】列不能为空;";
                    } else if(map.get(1)==null || "".equals(map.get(1))){
                        returnMsg += "第"+index+"行:【客户全称(必填)】列不能为空;";
                    } else {
                        int num = 0;
                        QueryCustomParam params = new QueryCustomParam();
                        params.setShortName(map.get(0));
                        params.setCorpId(Long.valueOf(u.getCorpId()));
                        num = customService.checkCustom(params); //查询相同客户
                        
                        if(num==0){
                            Custom custom = new Custom();
                            custom.setId(UUIDUtil.getLongUUID());
                            custom.setShortName(map.get(0)==null? null : map.get(0));
                            custom.setName(map.get(1)==null? null : map.get(1));
                            custom.setNumber(map.get(2)==null? null : map.get(2));
                            custom.setAddress(map.get(3)==null? null : map.get(3));
                            custom.setUrl(map.get(4)==null? null : map.get(4));
                            custom.setDescription(map.get(5)==null? null : map.get(5));
                            custom.setCustomStatusId(map.get(6)==null? null : basedataService.getLabelId("custom_status", map.get(6), corpId) ); 
                            custom.setCustomLevelId(map.get(7)==null? null : basedataService.getLabelId("custom_level", map.get(7), corpId) );         
                            custom.setCreaterId(Long.valueOf(u.getUserId()));
                            custom.setCreateDate(date);
                            custom.setUpdaterId(Long.valueOf(u.getUserId()));
                            custom.setUpdateDate(date);
                            custom.setCorpId(Long.valueOf(u.getCorpId()));
                            
                            list_.add(custom);
                            
                        } else {
                            returnMsg += "第"+index+"行:【客户简称(必填)】列:"+ map.get(0)+"已存在;";
                        }
                        index++;
                    }
                }
                
                int cuccess = customService.batchInsert(list_); //批量导入客户信息
                
                standardData.setReturnCode(0);
                standardData.setReturnData(null);
                
                error = count - success;
                standardData.setReturnMessage(returnMsg);
                
            } catch (Exception e) {
                log.error("批量导入客户信息异常:" + e.getMessage());
                standardData.setReturnMessage(e.getMessage());
            }
            
            return JsonHelper.encodeObject2Json(standardData, "yyyy-MM-dd HH:mm:ss");
        }
        

    读取Excel内容工具类:

    /**
         * 读取Excel数据内容
         * @param InputStream
         * @return List<Map<String, String>>  Map的key是列Id(0代表第一列),值是具体内容
         */
        public List<Map<Integer, String>> readExcelContentByList(InputStream is) {
            
            List<Map<Integer, String>> list = new ArrayList<Map<Integer,String>>();
            
            try {
                //fs = new POIFSFileSystem(is);
                wb = new HSSFWorkbook(is);
                //wb = new XSSFWorkbook(is);
            } catch (IOException e) {
                e.printStackTrace();
            }
            
            sheet = wb.getSheetAt(0);
            
            // 得到总行数
            int rowNum = sheet.getLastRowNum();
            row = sheet.getRow(0);
            int colNum = row.getPhysicalNumberOfCells();
            
            // 正文内容应该从第二行开始,第一行为表头的标题
            for (int i = 1; i <= rowNum; i++) {
                row = sheet.getRow(i);
                int j = 0;
                Map<Integer,String> map = new HashMap<Integer, String>();
                
                while (j < colNum) {
                    // 每个单元格的数据内容用"-"分割开,以后需要时用String类的replace()方法还原数据
                    // 也可以将每个单元格的数据设置到一个javabean的属性中,此时需要新建一个javabean
                    // str += getStringCellValue(row.getCell((short) j)).trim() +
                    // "-";
                    
                    map.put(j, getCellFormatValue(row.getCell((short) j)).trim().replaceAll("	
    ", ""));
                    //str += getCellFormatValue(row.getCell((short) j)).trim() + "    ";
                    j++;
                }
                list.add(map);
            }
            return list;
        }
        
  • 相关阅读:
    csrf攻击 使用js 调用 php文件的方法(还没实践)
    优化 要引入多个 模块 使用调用的方法,让管理更便捷 --execfile() 函数
    自动化 数据分离 --A文件里面的类 中的函数 调用 B文件里面类 的函数 的方法
    断言文件-封装方法 和 思路
    appium 元素文件 -查找元素 封装思路和方法
    appium的log详细分析
    链接多个数据库的方法
    修改phpMYadmin 链接其他数据库地址的方法
    搜索字段-预约时间
    用过的sql 工具
  • 原文地址:https://www.cnblogs.com/mingyue1818/p/4828865.html
Copyright © 2020-2023  润新知