当前位置: 首页 > 编程笔记 >

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

吴缪文
2023-03-14
本文向大家介绍Springboot+Poi导入Excel表格实现过程详解,包括了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();
      }
    }

  }

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

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

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

 类似资料:
  • 本文向大家介绍SpringBoot中EasyExcel实现Excel文件的导入导出,包括了SpringBoot中EasyExcel实现Excel文件的导入导出的使用技巧和注意事项,需要的朋友参考一下 前言 在我们日常的开发过程中经常会使用Excel文件的形式来批量地上传下载系统数据,我们最常用的工具是Apache poi,但是如果数据到底上百万时,将会造成内存溢出的问题,那么我们怎么去实现百万数据

  • 本文向大家介绍python实现数据写入excel表格,包括了python实现数据写入excel表格的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了python数据写入excel表格的具体代码,供大家参考,具体内容如下 安装: xlsxwriter第三方库 code: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 本文向大家介绍Springboot上传excel并将表格数据导入或更新mySql数据库的过程,包括了Springboot上传excel并将表格数据导入或更新mySql数据库的过程的使用技巧和注意事项,需要的朋友参考一下 本文主要描述,Springboot-mybatis框架下上传excel,并将之导入mysql数据库的过程,如果用户id已存在,则进行更新修改数据库中该项信息,由于用到的是前后端分离

  • 本文向大家介绍微信小程序 导入图标实现过程详解,包括了微信小程序 导入图标实现过程详解的使用技巧和注意事项,需要的朋友参考一下 图片素材库——阿里巴巴矢量图https://www.iconfont.cn/manage/index?manage_type=myprojects&projectId=1359989” 在页面输入要搜索的图标 点击“入库”,然后“添加至项目” 选择“编辑”,即对进行编辑成

  • 本文向大家介绍java实现Excel的导入、导出,包括了java实现Excel的导入、导出的使用技巧和注意事项,需要的朋友参考一下 一、Excel的导入 导入可采用两种方式,一种是JXL,另一种是POI,但前者不能读取高版本的Excel(07以上),后者更具兼容性。由于对两种方式都进行了尝试,就都贴出来分享(若有错误,请给予指正) 方式一、JXL导入  所需jar包 JXL.jar 方式二、POI

  • 本文向大家介绍公共POI导出Excel方法详解,包括了公共POI导出Excel方法详解的使用技巧和注意事项,需要的朋友参考一下 最早开始的时候做过一些数据Excel导出的功能,但是到后期每一次导出都需要写一些差不多类似的代码,稍微研究了一下写了个公共的导出方法。 这里用的是POI,然后写成了一个公共类,传入设置好格式的数据,就能弹出下载框。 (补充下getResponse的方法,之前没注意这个有继