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

 更新时间:2020年09月18日 15:48:46   作者:miracle2  
这篇文章主要介绍了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();
      }
    }

  }

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

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 详解Java线程中断知识点

    详解Java线程中断知识点

    在本篇文章中我们给大家分享了关于Java线程中断的相关知识点内容以及相关代码实例,有兴趣的朋友们可以学习下。
    2018-09-09
  • 基于Nacos实现Spring Cloud Gateway实现动态路由的方法

    基于Nacos实现Spring Cloud Gateway实现动态路由的方法

    这篇文章主要介绍了基于Nacos实现Spring Cloud Gateway实现动态路由的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • Lucene实现索引和查询的实例讲解

    Lucene实现索引和查询的实例讲解

    下面小编就为大家分享一篇Lucene实现索引和查询的实例讲解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12
  • 一篇文章彻底弄懂SpringBoot项目jdk版本及依赖不兼容问题

    一篇文章彻底弄懂SpringBoot项目jdk版本及依赖不兼容问题

    这篇文章主要给大家介绍了关于彻底弄懂SpringBoot项目jdk版本及依赖不兼容问题的相关资料,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2023-01-01
  • Java实现多文件上传功能

    Java实现多文件上传功能

    这篇文章主要为大家详细介绍了Java实现多文件上传功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-06-06
  • JAVA各种加密与解密方式总结大全

    JAVA各种加密与解密方式总结大全

    这篇文章主要给大家介绍了关于JAVA各种加密与解密方式总结的相关资料,加密是指对原来为明文的文件或数据按某种算法进行处理,使其成为不可读的一段代码,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • Java转JSON串的几种方式

    Java转JSON串的几种方式

    本文给大家总结一下java转json串的几种方式,每种方式通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随脚本之家小编一起学习吧
    2018-05-05
  • Spring Boot 项目启动失败的解决方案

    Spring Boot 项目启动失败的解决方案

    这篇文章主要介绍了Spring Boot 项目启动失败的解决方案,帮助大家更好的理解和学习使用Spring Boot,感兴趣的朋友可以了解下
    2021-03-03
  • 解决JTable排序问题的方法详解

    解决JTable排序问题的方法详解

    本篇文章是对JTable排序问题的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • java 通过发送json,post请求,返回json数据的方法

    java 通过发送json,post请求,返回json数据的方法

    下面小编就为大家分享一篇java 通过发送json,post请求,返回json数据的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03

最新评论