使用jxl导入excel文件

import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;

action中:

/**
     * 导入计划
     * @author liubf
     * @version 1.0
     * @createTime 2015-6-16
     */
    @RequestMapping("insertWBSPlan")
    public ResBean insertWBSPlan (HttpServletRequest request, HttpServletResponse response, ResBean handler) throws Exception {
        handler = new ResBean(SessionTools.getForBaseLoginDomainNo(request));
        Map<String, Object> parameter = new HashMap<String, Object>();
        try {
            Integer domainNo = SessionTools.getForBaseLoginDomainNo(request);
            if (domainNo == 0) {
                throw new AppException("获取域名失败!");
            }
            parameter.put("domainNo", domainNo);
            InputStream is = readUpload(request);
            if (is == null || "".equals(is)) {// 空文件
                handler.put("success", false);
                handler.put("msg", "上传文件为空!");
            }
            else{// 非空
                draftWBSService.readExcel(is,parameter);
                handler.put("success", true);
                handler.put("msg", "导入成功");
            }
        } catch (Exception e) {
            e.printStackTrace();
            log.error(e.getMessage(), e);
            handler.put("msg", e.getMessage());
            handler.put("error", true);
        }
    
        return handler;
    }
    
    
    /**
     * 读文件转为流
     * @param request
     * @return InputStream
     *  liubf
     * @throws Exception 
     */
    private InputStream readUpload(HttpServletRequest request) throws Exception {
        InputStream is = null;// 文件输入流
        MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
        CommonsMultipartFile orginalFile = (CommonsMultipartFile) multipartRequest.getFile("uploadFile");// 表单中对应的文件上传控件的名称;
        if (orginalFile != null && !orginalFile.isEmpty()) {// 如果有附件
            is = orginalFile.getInputStream();
        }
        return is;
    }

Service中:

/**
         * 导入计划
         */
        @SuppressWarnings("rawtypes")
        public void readExcel(InputStream is, Map<String, Object> parameter)
                throws Exception {
            HashMap resultMap = new HashMap();
            Workbook rwb = Workbook.getWorkbook(is);
            Sheet sheet = rwb.getSheets()[0];// 读取第一个sheet表格
//            List<TabAgHarvestForecast> insertlisth = new ArrayList<TabAgHarvestForecast>();           // 插入list
            //y用于存储从excel中读取的数据
            List<Map<String, String>> mapList = new ArrayList<Map<String, String>>();
            //获取已经存在的会员名称和编号
            List<HashMap> infoList = infoBeanDao.getMySqlMapClient().queryForList("com.forlink.bankfinancing.memberCredit.query_membercredit_list",new HashMap());
            //获取会员表中所有的会员名称,编号,id
            List<HashMap> tradeList = infoBeanDao.getMySqlMapClient().queryForList("com.forlink.bankfinancing.memberCredit.query_tradeMember_list");
            //新建 一个map存已经存在的会员名称和编号
            HashMap existMap = new HashMap();
            if(infoList!=null&&infoList.size()>0){
                for (HashMap map : infoList) {
                    existMap.put(map.get("cust_no").toString(),map.get("cust_name").toString());
                }
            }
            for (int i = 2; i < sheet.getRows(); i++) {
                Cell[] cel = sheet.getRow(i);
                String cust_no = "";
                String cust_name = "";
                String total_fund = "";
                String str6 = "";
                String cust_id = "";
                for (int j = 0; j < cel.length; j++) {
                    if (j == 0)
                        cust_no = cel[j].getContents().trim();
                    if (j == 1)
                        cust_name = cel[j].getContents().trim();
                    if (j == 2)
                        total_fund = cel[j].getContents().trim();
                    if (j == 3)
                        str6 = cel[j].getContents().trim();
                }
                if ((cust_no == null || "".equals(cust_no)) && (cust_name == null || "".equals(cust_name))
                        && (total_fund == null || "".equals(total_fund)) && (str6 == null || "".equals(str6))
                        ) {
                } else {
                    int flag = i+1;
                    int flag_exist = 0;
                    if(Double.parseDouble(total_fund)<0){
                        throw new AppException("第"+flag+"行总授信额度需大于等于0!");
                    }
                    //如果已经存在这个会员编号,但输入的编号和名称不对应, 则报错
                    if (existMap.containsKey(cust_no)) {
                        flag_exist = 1;
                        if(!cust_name.equals(existMap.get(cust_no)))
                            throw new AppException("第"+flag+"行会员编码和会员名称不对应!");
                    }else {
                        //如果不存在这个会员编号.则从会员表中查的所有会员与之比较
                        for(HashMap map : tradeList){
                            if(cust_no.equals((String)map.get("cust_no_trade"))){
                                flag_exist = 1;
                                //如果上传的cust_name和数据库中存的不一致则报错
                                if(!cust_name.equalsIgnoreCase((String)map.get("cust_name_trade"))){
                                    throw new AppException("第"+flag+"行会员编码和会员名称不对应!");
                                }else{
                                    cust_name = (String)map.get("cust_name_trade");
                                    cust_id = (String)map.get("cust_id_trade");
                                }
                            }
                        }
                    }
                    if(0 == flag_exist){
                        throw new AppException("第"+flag+"行会员不存在!");
                    }
                    for(Map m : mapList){
                        String rowNum = (String)m.get("rowNum");
                        if(cust_no.equals(m.get("cust_no"))){
                            throw new AppException("第"+flag+"行会员与第"+rowNum+"行会员重复!");
                        }
                    }
                    Map<String, String> map_temp = new HashMap<String, String>();
                    map_temp.put("cust_no", cust_no);
                    map_temp.put("cust_name", cust_name);
                    map_temp.put("cust_id", cust_id);
                    map_temp.put("total_fund", total_fund);
                    map_temp.put("str6", str6);
                    map_temp.put("rowNum",(""+flag));
                    mapList.add(map_temp);
                }
            }
            
                for (int j = mapList.size() - 1; j >= 0; j--) {
                    Map<String, String> map = mapList.get(j);

                    FacilityInfoBean infoBean = new FacilityInfoBean();
                    infoBean.setCustName(map.get("cust_name"));
                    infoBean.setCustNo(map.get("cust_no"));
                    infoBean.setStr6(map.get("str6"));
                    infoBean.setTotalFund(new Double(Double.parseDouble((map.get("total_fund")))*100).longValue());
                    if(StringUtils.isEmpty(map.get("cust_id"))){//为空说明已经有此条数据,update即可
                        FacilityInfoBeanExample infoBeanExample = new FacilityInfoBeanExample();
                        Criteria criteria = infoBeanExample.createCriteria();
                        criteria.andCustNoEqualTo(infoBean.getCustNo());
                        List<FacilityInfoBean> selectBeanList = infoBeanDao.selectByExample(infoBeanExample);
                        if(selectBeanList.size()>1||selectBeanList.size()<1){
                            throw new AppException("编号为"+infoBean.getCustNo()+"的数据不存在或存在重复数据!");
                        }
                        FacilityInfoBean selectInfoBean = selectBeanList.get(0);
                        selectInfoBean.setTotalFund(infoBean.getTotalFund());
                        selectInfoBean.setStr6(infoBean.getStr6());
                        selectInfoBean.setTotalAvb(infoBean.getTotalFund()-selectInfoBean.getTotalFrz());
                        infoBeanDao.updateByPrimaryKeySelective(selectInfoBean);
                    }else{
                        infoBean.setCustId(Long.parseLong(map.get("cust_id")));
                        infoBean.setOtherId(Long.parseLong(map.get("cust_id")));
                        infoBean.setTotalAvb(infoBean.getTotalFund());
                        //必填参数
                        //币种
                        infoBean.setCurrId(2L);
                        //授信类型
                        infoBean.setFacilityType(3L);
                        infoBean.setTotalFrz(0L);
                        infoBean.setTotalUsed(0L);
                        infoBean.setTotalOffset(0L);
                        infoBean.setNeedOffset(0L);
                        infoBean.setFrzOffset(0L);
                        infoBean.setTotalPassed(0L);
                        infoBean.setN1(0L);
                        infoBean.setN2(0L);
                        infoBean.setN3(0L);
                        infoBean.setN4(0L);
                        infoBean.setN5(0L);
                        infoBean.setN6(0L);
                        //获取域编号
                        Integer domainNo = (Integer)parameter.get("domainNo");
                        infoBean.setDomainNo(domainNo.longValue());
                        //建立时间
                        infoBean.setOperDate(new Timestamp(new Date().getTime()));
                        
                        
                        Long accept_id = getNextSeq("seq_facility_info");
                        infoBean.setAcceptId(accept_id);
                        //生成accept_no
                        String accept_id_str = ""+accept_id;
                        SimpleDateFormat format = new SimpleDateFormat("yyyyMMdd");
                        format.setTimeZone(TimeZone.getTimeZone("GMT+8")); 
                        String date = format.format(new Date());
                        String accept_no = "SX"+date+ accept_id_str.substring(accept_id_str.length()-2, accept_id_str.length());
                        infoBean.setAcceptNo(accept_no);
                        infoBeanDao.insertSelective(infoBean);
                    }
                }
        }

 

posted @ 2015-06-16 15:07  mr_level  阅读(506)  评论(0编辑  收藏  举报