Java SpringMVC项目导入excel2003以及2007多版本自动识别对应工具类(util)

本文主要是介绍Java SpringMVC项目导入excel2003以及2007多版本自动识别对应工具类(util),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

导入excel2003以及2007多版本自动识别对应工具类(util)


想出了一个工具类,希望对大家有用,导入excel生成对应的行的集合(list),集合里是对应列的Map。原生基于apache的poi类

Ps:之间还遇到了时间和电话号码转型问题,不知道为什么excel明明列设置了文本,但导入来的时候还是识别了数字类型,然后改良了代码,识别时间日期和数字类型返回字符串。


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


[java]  view plain copy
  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.   
  12.         try {  
  13.               
  14.             HSSFWorkbook wb = new HSSFWorkbook(templetFile.getInputStream());  
  15.             HSSFSheet sheet = wb.getSheetAt(sheetnum);                  //sheet 从0开始  
  16.             int rowNum = sheet.getLastRowNum() + 1;                     //取得最后一行的行号  
  17.   
  18.             for (int i = startrow; i < rowNum; i++) {                    //行循环开始  
  19.                   
  20.                 Map<String,String> varpd = new HashMap<String,String>();  
  21.                 HSSFRow row = sheet.getRow(i);                          //行  
  22.                 int cellNum = row.getLastCellNum();                     //每行的最后一个单元格位置  
  23.   
  24.                 for (int j = startcol; j < cellNum; j++) {               //列循环开始  
  25.           
  26.                     HSSFCell cell = row.getCell(Integer.parseInt(j + ""));  
  27.                     String cellValue = null;  
  28.                     if (null != cell) {  
  29.                         switch (cell.getCellType()) {                   // 判断excel单元格内容的格式,并对其进行转换,以便插入数据库  
  30.                         case 0:  
  31.                             if(HSSFDateUtil.isCellDateFormatted(cell)){  
  32.                                 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
  33.                                 cellValue=sdf.format(HSSFDateUtil.getJavaDate(cell.getNumericCellValue())).toString();  
  34.                             } else {  
  35.                                 cell.setCellType(1);  
  36.                                 cellValue = cell.getStringCellValue();  
  37.                             }  
  38.                             break;  
  39.                         case 1:  
  40.                             cellValue = cell.getStringCellValue();  
  41.                             break;  
  42.                         case 2:  
  43.                             //cell.setCellType(1);  
  44.                             //cellValue = cell.getStringCellValue();  
  45.                             //cellValue = cell.getNumericCellValue() + "";  
  46.                              cellValue = String.valueOf(cell.getDateCellValue());  
  47.                             break;  
  48.                         case 3:  
  49.                             cellValue = "";  
  50.                             break;  
  51.                         case 4:  
  52.                             cellValue = String.valueOf(cell.getBooleanCellValue());  
  53.                             break;  
  54.                         case 5:  
  55.                             cellValue = String.valueOf(cell.getErrorCellValue());  
  56.                             break;  
  57.                         }  
  58.                     } else {  
  59.                         cellValue = "";  
  60.                     }  
  61.                       
  62.                     varpd.put("var"+j, cellValue);  
  63.                       
  64.                 }  
  65.                 varList.add(varpd);  
  66.             }  
  67.   
  68.         } catch (Exception e) {  
  69.             System.out.println(e);  
  70.         }  
  71.           
  72.         return varList;  
  73.     }  


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


[javascript]  view plain copy
  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.   
  12.         try {  
  13.               
  14.             XSSFWorkbook wb = new XSSFWorkbook(templetFile.getInputStream());  
  15.             XSSFSheet sheet = wb.getSheetAt(sheetnum);                  //sheet 从0开始  
  16.             int rowNum = sheet.getLastRowNum() + 1;                     //取得最后一行的行号  
  17.   
  18.             for (int i = startrow; i < rowNum; i++) {                    //行循环开始  
  19.                   
  20.                 Map<String,String> varpd = new HashMap<String,String>();  
  21.                 XSSFRow row = sheet.getRow(i);                          //行  
  22.                 int cellNum = row.getLastCellNum();                     //每行的最后一个单元格位置  
  23.   
  24.                 for (int j = startcol; j < cellNum; j++) {               //列循环开始  
  25.                       
  26.                     XSSFCell cell = row.getCell(Integer.parseInt(j + ""));  
  27.                     String cellValue = null;  
  28.                     if (null != cell) {  
  29.                         switch (cell.getCellType()) {                   // 判断excel单元格内容的格式,并对其进行转换,以便插入数据库  
  30.                         case 0:               
  31.                             if(HSSFDateUtil.isCellDateFormatted(cell)){  
  32.                                 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
  33.                                 cellValue=sdf.format(HSSFDateUtil.getJavaDate(cell.getNumericCellValue())).toString();  
  34.                             } else {  
  35.                                 cell.setCellType(1);  
  36.                                 cellValue = cell.getStringCellValue();  
  37.                             }  
  38.                             break;  
  39.                         case 1:  
  40.                             cellValue = cell.getStringCellValue();  
  41.                             break;  
  42.                         case 2:  
  43.                             cellValue = cell.getStringCellValue();  
  44.                             //cellValue = cell.getNumericCellValue() + "";  
  45.                             // cellValue = String.valueOf(cell.getDateCellValue());  
  46.                             break;  
  47.                         case 3:  
  48.                             cellValue = "";  
  49.                             break;  
  50.                         case 4:  
  51.                             cellValue = String.valueOf(cell.getBooleanCellValue());  
  52.                             break;  
  53.                         case 5:  
  54.                             cellValue = String.valueOf(cell.getErrorCellValue());  
  55.                             break;  
  56.                         }  
  57.                     } else {  
  58.                         cellValue = "";  
  59.                     }  
  60.                       
  61.                     varpd.put("var"+j, cellValue);  
  62.                       
  63.                 }  
  64.                 varList.add(varpd);  
  65.             }  
  66.   
  67.         } catch (Exception e) {  
  68.             System.out.println(e);  
  69.         }  
  70.           
  71.         return varList;  
  72.     }  

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

[java]  view plain copy
  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.     }  

这篇关于Java SpringMVC项目导入excel2003以及2007多版本自动识别对应工具类(util)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/927744

相关文章

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Mac系统下卸载JAVA和JDK的步骤

《Mac系统下卸载JAVA和JDK的步骤》JDK是Java语言的软件开发工具包,它提供了开发和运行Java应用程序所需的工具、库和资源,:本文主要介绍Mac系统下卸载JAVA和JDK的相关资料,需... 目录1. 卸载系统自带的 Java 版本检查当前 Java 版本通过命令卸载系统 Java2. 卸载自定

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

SpringMVC高效获取JavaBean对象指南

《SpringMVC高效获取JavaBean对象指南》SpringMVC通过数据绑定自动将请求参数映射到JavaBean,支持表单、URL及JSON数据,需用@ModelAttribute、@Requ... 目录Spring MVC 获取 JavaBean 对象指南核心机制:数据绑定实现步骤1. 定义 Ja

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor