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. Dojo入门:增强的Ajax功能

      随着Web技术的发展,RIA似乎已经成了主流,Ajax也随之成了不可或缺的部分.Ajax是异步的javascript和Xml,虽然现在很多交互的数据格式都不再严格的采用XML,但这种异步的操作却越 ...

  2. golang remote debug和docker debug

    在编写 Go 代码的时候,因为很多时候都是需要调试服务器上的代码的,作为一个年长的工程师,肯定不能用 log.Printf 来调试问题,所以我选择了 delve 这个工具,通过 delve 我可以像本 ...

  3. Unity中的动画系统和Timeline(5) Timeline

    在前面的动画,都是控制单独的物体,比如说控制一个角色的运动.而Timeline,可以对多个物体实施动画,形成过场动画,或者电影效果.比如,很多赛车游戏比赛开始前都会播放一段开场动画,围绕自己车的几个方 ...

  4. VGA显示正圆

    接着上次的随笔,既然VGA时序已经实现了,那么就显示点东西看看吧. 想显示个圆,但是无从下手,参考了这篇文章:https://user.qzone.qq.com/1241003385/blog/154 ...

  5. oracle分页排序,点击下一页数据不刷新

    oracle数据库中,如果每一页的最后一条和次页第一条数据的排序字段重复,会导致排序混乱,出现点击下一页数据不刷新的现象,所以一般排序至少选择一个相对唯一的字段.在前端页面可以输入排序条件的场景中,最 ...

  6. 【神经网络与深度学习】Caffe使用step by step:caffe框架下的基本操作和分析

    caffe虽然已经安装了快一个月了,但是caffe使用进展比较缓慢,果然如刘老师说的那样,搭建起来caffe框架环境比较简单,但是完整的从数据准备->模型训练->调参数->合理结果需 ...

  7. 深入理解java:2.4. 线程本地变量 java.lang.ThreadLocal类

    ThreadLocal,很多人都叫它做线程本地变量,也有些地方叫做线程本地存储,其实意思差不多. 可能很多朋友都知道ThreadLocal为变量在每个线程中都创建了一个副本,那样每个线程可以访问自己内 ...

  8. Python流程控制与while 循环(day01)

    一:流程控制 假如把写程序比做走路,那我们到现在为止,一直走的都是直路,还没遇到过分叉口,想象现实中,你遇到了分叉口,然后你决定往哪拐必然是有所动机的.你要判断哪条叉路是你真正要走的路,如果我们想让 ...

  9. 设置Eclipse代码自动提示

    对于编程人员来说,要记住大量的类名或类方法的名字,着实不是一件容易的事情.如果要IDE能够自动补全代码,那将为我们编程人员带来很大帮助. Eclipse代码里面的代码提示功能默认是关闭的,只有输入“. ...

  10. 【7.9校内test】T1挖地雷

    (土气的名字万里挑一丫丫) 然后这个题是个递推,lz的考场想法: 3个的最好确定,先把3个的确定下来,然后从这个点往前推,从这个点往后推这么算吧qwq 然后码长:也是很nice,最关键的是,我都写的这 ...