POI导入相关实例代码

导入

    //导入
    @RequestMapping("/basicinfo/factory/importInfo.action")
    public String importInfo() throws InvalidFormatException, IOException{
        /*
         * 开发步骤:
         * 1、读取xls文件;创建模板,设置所有单元格为文本类型,然后黏贴数据到editplus,再黏贴到excel中,这样就不怕读取类型错误。
         * 2、拼接成sql
         * 3、批量插入
         */

        //实现自动识别读取的xls版本,创建其对应的对象; 2003 HSSFWorkbook对象;2007 XSSFWorkbook对象
        String sql = "";
        File file = new File("c:\\7F28E200.xlsx");
        Workbook wb = new WorkbookFactory().create(file);       //自动识别excel版本
        Sheet sheet = wb.getSheetAt(0);

        Row nRow = sheet.getRow(1);
        Cell nCell = null;

        //是否标题行,标题行还可以多列
        int beginRowNo = 0;                             //开始行
        int endRowNo =  sheet.getLastRowNum();          //结束行
        int beginColNo = 0;                             //开始列
        int endColNo = nRow.getLastCellNum();           //结束列

        StringBuffer sBuf = new StringBuffer();
        for(int i=beginRowNo;i<endRowNo;i++){
            nRow = sheet.getRow(i);                     //行对象
//          
//          for(int j=beginColNo;j<endColNo;j++){
//              nCell = nRow.getCell(j++);              //单元格
//              System.out.println(nCell.toString());
//          }

            beginColNo = 0;                             //开始列
//          

            sBuf.append("insert into factory_c (FACTORY_ID,FULL_NAME,FACTORY_NAME,CONTACTS,PHONE,MOBILE,FAX,INSPECTOR,CNOTE,ORDER_NO,STATE,CREATE_BY,CREATE_DEPT,CREATE_TIME) ");
            sBuf.append("values(");

            nCell = nRow.getCell(beginColNo++); 
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            //orderNo
            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("null");
            }else{
                sBuf.append(UtilFuns.convertNull(nCell.getStringCellValue()));
            }
            sBuf.append(",");

            //state
            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("null");
            }else{
                sBuf.append(UtilFuns.convertNull(nCell.getStringCellValue()));
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("''");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }
            sBuf.append(",");

            nCell = nRow.getCell(beginColNo++);     
            if(nCell==null){
                sBuf.append("NULL");
            }else{
                sBuf.append("'").append(UtilFuns.convertNull(nCell.getStringCellValue())).append("'");
            }

            sBuf.append(");");

        }
        for(String s : sBuf.toString().split(";")){
            System.out.println(s);
        }

        sqlDao.batchSQL(sBuf.toString().split(";"));        //执行insert sql

        return "redirect:/basicinfo/factory/list.action";
    }
发布了30 篇原创文章 · 获赞 8 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/wsl9420/article/details/53266639