纯净、安全、绿色的下载网站

首页|软件分类|下载排行|最新软件|IT学院

当前位置:首页IT学院IT技术 → Springboot+Poi导入Excel表格实现过程详解

Springboot+Poi导入Excel表格实现过程详解

miracle2   2020-09-18 我要评论

本文着重讲解了Springboot+Poi导入Excel表格实现过程详解,文中通过代码实例讲解的非常细致,对大家的工作和学习具有一定的参考学习价值,欢迎大家阅读和收藏

导入表格的主要思路就是:首先从前端页面上传文件,这里先区分一下Multipartfile和File,前者代表的是HTML中form data方式上传的文件,后者是文件系统的抽象,前者信息较少,只有二进制数据+文件名称,所以我们一般先上传的Multipartfile文件要转换成File文件我们才可以读取文件的内容。下面一步一步的讲解

Tips:

1、先生成临时文件,同时记得使用transferTo()方法把MultipartFile文件类型转成File类型:

File excelFile=excelService.temp(file);
//对应的temp()方法
  public File temp(MultipartFile multipartFile) throws IOException {
    //这里用系统当前时间加文件后缀名来做临时文件的名字,防止生成的临时文件重复
    final File excelFile=File.createTempFile(new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()),Prefix(multipartFile));
    //把MulitipartFile 文件转成File文件
    multipartFile.transferTo(excelFile);
    return excelFile;
  }

2、生成临时文件之后我们就可以取解析这个临时文件的内容了:

//开始从临时文件中取出数据进行解析
      sysVeterinaryList=excelService.readExcel(excelFile);

//readExcel()的具体实现如下:
 public List<SysVeterinary> readExcel(File file) throws IOException {

    List<SysVeterinary> sysVeterinaryList =new ArrayList<>();
    Workbook workbook;
    try{
      //操作07版本后的Excel表格,扩展名是.xlsx
      workbook = new XSSFWorkbook(file);
    } catch (Exception e) {
      //操作的是03年及以前的版本,扩展名为.xls
      workbook = new HSSFWorkbook(new FileInputStream(file));
    }

    //选择第一个工作簿,即第一个表格
    Sheet sheets = workbook.getSheetAt(0);
    //getPhysicalNumberOfRows获取的是物理行数,就是不包括那些空行(隔行的)的情况
    //表格的第0行是表头,标识每个字段,所以这里直接从第一行开始解析数据
    for(int i=1;i<sheets.getPhysicalNumberOfRows();i++){
      Row row = sheets.getRow(i);
      try{
        SysVeterinary sysVeterinary = new SysVeterinary();
        String[] strrs=getString(row);
        if(!strrs[0].equals("")&&!strrs[1].equals("")&&!strrs[2].equals("")&&!strrs[3].equals("")&&!strrs[4].equals("")&&!strrs[5].equals("")&&!strrs[6].equals("")){
          //名称
          sysVeterinary.setVeterinaryName(strrs[0]);
          //地址
          sysVeterinary.setVeterinaryAddress(strrs[1]);
          //经度
          sysVeterinary.setVeterinaryLongitude(strrs[2]);
          //纬度
          sysVeterinary.setVeterinaryLatitude(strrs[3]);
          //联系方式
          sysVeterinary.setVeterinaryPhone(strrs[4]);
          //户主名
          sysVeterinary.setVeterinaryStoreKeeper(strrs[5]);
          //兽医店规模
          sysVeterinary.setVeterinaryScope(strrs[6]);
          //技术水平
          sysVeterinary.setVeterinarySkill(strrs[7]);
          sysVeterinaryList.add(sysVeterinary);
        }else {
          System.out.println("无效行数"+i);
        }
      }catch (Exception e){
        e.printStackTrace();
      }
    }
    return sysVeterinaryList;
  }

3、第2点的红色代码主要是对每一行的单元格数据进行操作,就是我先把这一行的所有单元格内容的类型全部转换成String类型,如果最后要存进数据库的类型不是字符串类型的话,那我们就可以在具体赋值之前再转成我们想要的类型就可以了,下面是把单元格转成String的方法:

/**
   * //该方法是把每行的单元格内容全部都先转成字符传类型,再一一读取
   * @param row
   * @return
   */

  public String[] getString(Row row){
    String[] strs=new String[8];
    for(int j =0;j<strs.length;j++){
      //把行内的单元格内容当作字符串获取,,单元格的第一行是序号,不需要入库,所以这里从第二各单元格开始
      row.getCell(j+1).setCellType(CellType.STRING);
      //获取某个单元格里面的值
      strs[j] = row.getCell(j+1).getStringCellValue();
    }
    return strs;

  }

4、在第2点中解析完返回的数据就是我们最终要保存到数据库里面的数据了,当我们解析完这个临时文件的时候我们就可以把之前生成的临时文件给删除了,具体的代码如下:

//每次解析完就删除临时文件
      excelService.deleteFile(excelFile);
//实现
  /**
   * 删除之前生成的临时文件,参数File... 这样子定义的意思
   * 是表示参数的个数是不确顶的,因为上传文件的时候,有可能会同时上传几个文件
   * @param files
   */

  public void deleteFile(File... files){
    for(File file:files){
      if(file.exists()){
        file.delete();
      }
    }

  }

做完上面一系列的操作,数据解析完了

其实上面的还是不算完善的,比如如果导入的数据量非常大的时候,我们就可以先做一个判断,就是每次读取? 导入?的条数是有限制的,就是一次性只能存多少条,存完再寻接下来的。


相关文章

猜您喜欢

  • 万万没想到Chrome的历史记录竟然可以这么玩

    最近遇到一个棘手的问题,需要查找含有某个关键字的网页,但是通过chrome原生的历史记录查出来的,查到的结果并不满意,今天小编就给大家分享一篇教程帮助大家解决Chrome历史记录的问题,感兴趣的朋友一起看看吧..
  • springMVC怎样对输入数据校验实现代码

    数据的校验是交互式网站一个不可或缺的功能,数据验证分为客户端验证和服务器端验证,本文着重讲解了springMVC怎样对输入数据校验,欢迎大家阅读和收藏..

网友评论

Copyright 2020 www.mmKan.net 【漫漫看下载站】 版权所有

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 点此查看联系方式