1.首先是导入Excel2003以前(包括2003)的版本,扩展名是.xls 的

  1. /**
  2. * 操作Excel2003以前(包括2003)的版本,扩展名是.xls
  3. * @param templetFile 文件
  4. * @param startrow 开始行号
  5. * @param startcol 开始列号
  6. * @param sheetnum sheet
  7. * @return list
  8. */
  9. public static List<Map<String,String>> readExcelByXls(MultipartFile templetFile, int startrow, int startcol, int sheetnum) {
  10. List<Map<String,String>> varList = new ArrayList<Map<String,String>>();
  11. try {
  12. HSSFWorkbook wb = new HSSFWorkbook(templetFile.getInputStream());
  13. HSSFSheet sheet = wb.getSheetAt(sheetnum);                  //sheet 从0开始
  14. int rowNum = sheet.getLastRowNum() + 1;                     //取得最后一行的行号
  15. for (int i = startrow; i < rowNum; i++) {                    //行循环开始
  16. Map<String,String> varpd = new HashMap<String,String>();
  17. HSSFRow row = sheet.getRow(i);                          //行
  18. int cellNum = row.getLastCellNum();                     //每行的最后一个单元格位置
  19. for (int j = startcol; j < cellNum; j++) {               //列循环开始
  20. HSSFCell cell = row.getCell(Integer.parseInt(j + ""));
  21. String cellValue = null;
  22. if (null != cell) {
  23. switch (cell.getCellType()) {                   // 判断excel单元格内容的格式,并对其进行转换,以便插入数据库
  24. case 0:
  25. if(HSSFDateUtil.isCellDateFormatted(cell)){
  26. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  27. cellValue=sdf.format(HSSFDateUtil.getJavaDate(cell.getNumericCellValue())).toString();
  28. } else {
  29. cell.setCellType(1);
  30. cellValue = cell.getStringCellValue();
  31. }
  32. break;
  33. case 1:
  34. cellValue = cell.getStringCellValue();
  35. break;
  36. case 2:
  37. //cell.setCellType(1);
  38. //cellValue = cell.getStringCellValue();
  39. //cellValue = cell.getNumericCellValue() + "";
  40. cellValue = String.valueOf(cell.getDateCellValue());
  41. break;
  42. case 3:
  43. cellValue = "";
  44. break;
  45. case 4:
  46. cellValue = String.valueOf(cell.getBooleanCellValue());
  47. break;
  48. case 5:
  49. cellValue = String.valueOf(cell.getErrorCellValue());
  50. break;
  51. }
  52. } else {
  53. cellValue = "";
  54. }
  55. varpd.put("var"+j, cellValue);
  56. }
  57. varList.add(varpd);
  58. }
  59. } catch (Exception e) {
  60. System.out.println(e);
  61. }
  62. return varList;
  63. }

2.是操作Excel2007的版本,扩展名是.xlsx的


  1. /**
  2. * 是操作Excel2007的版本,扩展名是.xlsx
  3. * @param templetFile 文件
  4. * @param startrow 开始行号
  5. * @param startcol 开始列号
  6. * @param sheetnum sheet
  7. * @return list
  8. */
  9. public static List<Map<String,String>> readExcelByXlsx(MultipartFile templetFile, int startrow, int startcol, int sheetnum) {
  10. List<Map<String,String>> varList = new ArrayList<Map<String,String>>();
  11. try {
  12. XSSFWorkbook wb = new XSSFWorkbook(templetFile.getInputStream());
  13. XSSFSheet sheet = wb.getSheetAt(sheetnum);                  //sheet 从0开始
  14. int rowNum = sheet.getLastRowNum() + 1;                     //取得最后一行的行号
  15. for (int i = startrow; i < rowNum; i++) {                    //行循环开始
  16. Map<String,String> varpd = new HashMap<String,String>();
  17. XSSFRow row = sheet.getRow(i);                          //行
  18. int cellNum = row.getLastCellNum();                     //每行的最后一个单元格位置
  19. for (int j = startcol; j < cellNum; j++) {               //列循环开始
  20. XSSFCell cell = row.getCell(Integer.parseInt(j + ""));
  21. String cellValue = null;
  22. if (null != cell) {
  23. switch (cell.getCellType()) {                   // 判断excel单元格内容的格式,并对其进行转换,以便插入数据库
  24. case 0:
  25. if(HSSFDateUtil.isCellDateFormatted(cell)){
  26. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  27. cellValue=sdf.format(HSSFDateUtil.getJavaDate(cell.getNumericCellValue())).toString();
  28. } else {
  29. cell.setCellType(1);
  30. cellValue = cell.getStringCellValue();
  31. }
  32. break;
  33. case 1:
  34. cellValue = cell.getStringCellValue();
  35. break;
  36. case 2:
  37. cellValue = cell.getStringCellValue();
  38. //cellValue = cell.getNumericCellValue() + "";
  39. // cellValue = String.valueOf(cell.getDateCellValue());
  40. break;
  41. case 3:
  42. cellValue = "";
  43. break;
  44. case 4:
  45. cellValue = String.valueOf(cell.getBooleanCellValue());
  46. break;
  47. case 5:
  48. cellValue = String.valueOf(cell.getErrorCellValue());
  49. break;
  50. }
  51. } else {
  52. cellValue = "";
  53. }
  54. varpd.put("var"+j, cellValue);
  55. }
  56. varList.add(varpd);
  57. }
  58. } catch (Exception e) {
  59. System.out.println(e);
  60. }
  61. return varList;
  62. }

3.重点来了,结合前两个代码使用,自动识别excel版本文件

    1. public static List<Map<String,String>> readExcel(MultipartFile templetFile, int startrow, int startcol, int sheetnum){
    2. List<Map<String,String>> varList = new ArrayList<Map<String,String>>();
    3. if(templetFile!=null&&templetFile.getSize()>0){
    4. String ofn=templetFile.getOriginalFilename();// 文件名
    5. String extName = ""; // 扩展名格式:
    6. if (ofn.lastIndexOf(".") >= 0){
    7. extName = ofn.substring(ofn.lastIndexOf("."));
    8. }
    9. if(".xls".equals(extName.toLowerCase())){
    10. varList=readExcelByXls(templetFile,startrow,startcol,sheetnum);
    11. }else if(".xlsx".equals(extName.toLowerCase())){
    12. varList=readExcelByXlsx(templetFile,startrow,startcol,sheetnum);
    13. }
    14. }
    15. return varList;
    16. }

导入Excel扩展名是.xls 和.xlsx的的更多相关文章

  1. Java解析Excel工具类(兼容xls和xlsx)

    依赖jar <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml&l ...

  2. 电脑右键新建excel工作表,但是扩展名是.xls,而不是.xlsx

    怀疑是因为之前安装了wps,然后又卸载了,导致的.上网查阅,如下: excel默认新建xls 不是我的问题 Excel 2010/2013/2016在鼠标右键新建xls或xlsx文件后,打开报错“无法 ...

  3. Java 打开Excel,往Excel中存入值,保存的excel格式分别是xls和xlsx

    https://mirrors.cnnic.cn/apache/poi/xmlbeans/release/src/ package Excel; import org.apache.poi.hssf. ...

  4. Java读取Excel文件(包括xls和xlsx)的样例程序

    样例程序如下所示,其中: parseXls()函数依赖于jxl,只能读取xls格式文件: parseExcel()函数依赖于apache poi,能够读取xls和xlsx两种格式的文件. jxl的依赖 ...

  5. C#:导入Excel通用类(Xls格式)

    PS:在CSV格式和XLSX格式中有写到通用调用的接口和引用的插件,所以在这个xls格式里面并没有那么详细,只是配上xls通用类. 一.引用插件NPOI.dll.NPOI.OOXML.dll.NPOI ...

  6. NPOI读取excel功能,兼容xls和xlsx

    样例: IWorkbook workbook; string fileExt = Path.GetExtension(filePath); try { using (var file = new Fi ...

  7. JAVA POI XSSFWorkbook导出扩展名为xlsx的Excel,附带weblogic 项目导出Excel文件错误的解决方案

    现在很多系统都有导出excel的功能,总结一下自己之前写的,希望能帮到其他人,这里我用的是XSSFWorkbook,我们项目在winsang 用的Tomcat,LInux上用的weblogic服务器, ...

  8. 打开Excel时提示"您尝试打开的文件**.xls的格式与文件扩展名指定的格式不一致"

    问题描述:     系统安装了WPS时,Analyzer导出excel时候,会提示"您尝试打开的文件**.xls的格式与文件扩展名指定的格式不一致",这是Excel的安全问题,   ...

  9. Excel导入工具类兼容xls和xlsx

    package com.bj58.finance.platform.operation.provider.util; import org.apache.log4j.Logger; import or ...

随机推荐

  1. 如何理解springcloud微服务项目中,eureka,provider,consumer它们之间的关系?

    eureka负责注册provider和consumer的服务信息 provider负责与数据库进行交互,实现数据持久化,并给consumer提供服务 consumer与前端交互,通过与Eureka同源 ...

  2. ssh端口转发功能

    一.SSH 端口转发能够提供两大功能: 1.加密SSH Client 端至SSH Server 端之间的通讯数据 2.突破防火墙的限制完成一些之前无法建立的TCP 连接  (隧道功能) 二:SSH端口 ...

  3. spring实战第五版总结

  4. 2031 HDOJ 进制转换

    Problem Description 输入一个十进制数N,将它转换成R进制数输出.   Input 输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(2<=R<=1 ...

  5. Angular5 *ngIf 和 hidden 的区别

    问题 项目中遇到一个问题,有一个过滤查询的面板,需要通过一个展开折叠的button,来控制它的show 和 hide.这个面板中,有一个Select 组件,一个 input 查询输入框. 原来代码是: ...

  6. Linux用ICMP协议实现简单Ping网络监测功能

    ICMP是(Internet Control Message Protocol)Internet控制报文协议.它是TCP/IP协议族的一个子协议,用于在IP主机.路由器之间传递控制消息.控制消息是指网 ...

  7. [Python3] 027 常用模块 time

    目录 time 1. 时间戳 2. UTC 时间 3. 夏令时 4. 时间元组 5. 举例 5.1 例子1 例子2 例子3 例子4 例子5 例子6 例子7 time 1. 时间戳 一个时间表示,根据不 ...

  8. Statistics项目学习笔记

    1. http://218.244.157.0:55443/index.html 初始访问时,弹出的窗口为index.html文件,文件有html命令组成.html展现的UI界面用的是WIN10-UI ...

  9. maven坐标Dependencies和Exclusions详解

    1.概念介绍 Dependencies:是可选依赖(Optional Dependencies) Exclusions:是依赖排除(Dependency Exclusions) 2.Dependenc ...

  10. numpy中的快速的元素级数组函数

    numpy中的快速的元素级数组函数 一元(unary)ufunc 对于数组中的每一个元素,都将元素代入函数,将得到的结果放回到原来的位置 >>> import numpy as np ...