导入Excel扩展名是.xls 和.xlsx的
1.首先是导入Excel2003以前(包括2003)的版本,扩展名是.xls 的
- /**
- * 操作Excel2003以前(包括2003)的版本,扩展名是.xls
- * @param templetFile 文件
- * @param startrow 开始行号
- * @param startcol 开始列号
- * @param sheetnum sheet
- * @return list
- */
- public static List<Map<String,String>> readExcelByXls(MultipartFile templetFile, int startrow, int startcol, int sheetnum) {
- List<Map<String,String>> varList = new ArrayList<Map<String,String>>();
- try {
- HSSFWorkbook wb = new HSSFWorkbook(templetFile.getInputStream());
- HSSFSheet sheet = wb.getSheetAt(sheetnum); //sheet 从0开始
- int rowNum = sheet.getLastRowNum() + 1; //取得最后一行的行号
- for (int i = startrow; i < rowNum; i++) { //行循环开始
- Map<String,String> varpd = new HashMap<String,String>();
- HSSFRow row = sheet.getRow(i); //行
- int cellNum = row.getLastCellNum(); //每行的最后一个单元格位置
- for (int j = startcol; j < cellNum; j++) { //列循环开始
- HSSFCell cell = row.getCell(Integer.parseInt(j + ""));
- String cellValue = null;
- if (null != cell) {
- switch (cell.getCellType()) { // 判断excel单元格内容的格式,并对其进行转换,以便插入数据库
- case 0:
- if(HSSFDateUtil.isCellDateFormatted(cell)){
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
- cellValue=sdf.format(HSSFDateUtil.getJavaDate(cell.getNumericCellValue())).toString();
- } else {
- cell.setCellType(1);
- cellValue = cell.getStringCellValue();
- }
- break;
- case 1:
- cellValue = cell.getStringCellValue();
- break;
- case 2:
- //cell.setCellType(1);
- //cellValue = cell.getStringCellValue();
- //cellValue = cell.getNumericCellValue() + "";
- cellValue = String.valueOf(cell.getDateCellValue());
- break;
- case 3:
- cellValue = "";
- break;
- case 4:
- cellValue = String.valueOf(cell.getBooleanCellValue());
- break;
- case 5:
- cellValue = String.valueOf(cell.getErrorCellValue());
- break;
- }
- } else {
- cellValue = "";
- }
- varpd.put("var"+j, cellValue);
- }
- varList.add(varpd);
- }
- } catch (Exception e) {
- System.out.println(e);
- }
- return varList;
- }
2.是操作Excel2007的版本,扩展名是.xlsx的
- /**
- * 是操作Excel2007的版本,扩展名是.xlsx
- * @param templetFile 文件
- * @param startrow 开始行号
- * @param startcol 开始列号
- * @param sheetnum sheet
- * @return list
- */
- public static List<Map<String,String>> readExcelByXlsx(MultipartFile templetFile, int startrow, int startcol, int sheetnum) {
- List<Map<String,String>> varList = new ArrayList<Map<String,String>>();
- try {
- XSSFWorkbook wb = new XSSFWorkbook(templetFile.getInputStream());
- XSSFSheet sheet = wb.getSheetAt(sheetnum); //sheet 从0开始
- int rowNum = sheet.getLastRowNum() + 1; //取得最后一行的行号
- for (int i = startrow; i < rowNum; i++) { //行循环开始
- Map<String,String> varpd = new HashMap<String,String>();
- XSSFRow row = sheet.getRow(i); //行
- int cellNum = row.getLastCellNum(); //每行的最后一个单元格位置
- for (int j = startcol; j < cellNum; j++) { //列循环开始
- XSSFCell cell = row.getCell(Integer.parseInt(j + ""));
- String cellValue = null;
- if (null != cell) {
- switch (cell.getCellType()) { // 判断excel单元格内容的格式,并对其进行转换,以便插入数据库
- case 0:
- if(HSSFDateUtil.isCellDateFormatted(cell)){
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
- cellValue=sdf.format(HSSFDateUtil.getJavaDate(cell.getNumericCellValue())).toString();
- } else {
- cell.setCellType(1);
- cellValue = cell.getStringCellValue();
- }
- break;
- case 1:
- cellValue = cell.getStringCellValue();
- break;
- case 2:
- cellValue = cell.getStringCellValue();
- //cellValue = cell.getNumericCellValue() + "";
- // cellValue = String.valueOf(cell.getDateCellValue());
- break;
- case 3:
- cellValue = "";
- break;
- case 4:
- cellValue = String.valueOf(cell.getBooleanCellValue());
- break;
- case 5:
- cellValue = String.valueOf(cell.getErrorCellValue());
- break;
- }
- } else {
- cellValue = "";
- }
- varpd.put("var"+j, cellValue);
- }
- varList.add(varpd);
- }
- } catch (Exception e) {
- System.out.println(e);
- }
- return varList;
- }
3.重点来了,结合前两个代码使用,自动识别excel版本文件
- public static List<Map<String,String>> readExcel(MultipartFile templetFile, int startrow, int startcol, int sheetnum){
- List<Map<String,String>> varList = new ArrayList<Map<String,String>>();
- if(templetFile!=null&&templetFile.getSize()>0){
- String ofn=templetFile.getOriginalFilename();// 文件名
- String extName = ""; // 扩展名格式:
- if (ofn.lastIndexOf(".") >= 0){
- extName = ofn.substring(ofn.lastIndexOf("."));
- }
- if(".xls".equals(extName.toLowerCase())){
- varList=readExcelByXls(templetFile,startrow,startcol,sheetnum);
- }else if(".xlsx".equals(extName.toLowerCase())){
- varList=readExcelByXlsx(templetFile,startrow,startcol,sheetnum);
- }
- }
- return varList;
- }
导入Excel扩展名是.xls 和.xlsx的的更多相关文章
- Java解析Excel工具类(兼容xls和xlsx)
依赖jar <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml&l ...
- 电脑右键新建excel工作表,但是扩展名是.xls,而不是.xlsx
怀疑是因为之前安装了wps,然后又卸载了,导致的.上网查阅,如下: excel默认新建xls 不是我的问题 Excel 2010/2013/2016在鼠标右键新建xls或xlsx文件后,打开报错“无法 ...
- Java 打开Excel,往Excel中存入值,保存的excel格式分别是xls和xlsx
https://mirrors.cnnic.cn/apache/poi/xmlbeans/release/src/ package Excel; import org.apache.poi.hssf. ...
- Java读取Excel文件(包括xls和xlsx)的样例程序
样例程序如下所示,其中: parseXls()函数依赖于jxl,只能读取xls格式文件: parseExcel()函数依赖于apache poi,能够读取xls和xlsx两种格式的文件. jxl的依赖 ...
- C#:导入Excel通用类(Xls格式)
PS:在CSV格式和XLSX格式中有写到通用调用的接口和引用的插件,所以在这个xls格式里面并没有那么详细,只是配上xls通用类. 一.引用插件NPOI.dll.NPOI.OOXML.dll.NPOI ...
- NPOI读取excel功能,兼容xls和xlsx
样例: IWorkbook workbook; string fileExt = Path.GetExtension(filePath); try { using (var file = new Fi ...
- JAVA POI XSSFWorkbook导出扩展名为xlsx的Excel,附带weblogic 项目导出Excel文件错误的解决方案
现在很多系统都有导出excel的功能,总结一下自己之前写的,希望能帮到其他人,这里我用的是XSSFWorkbook,我们项目在winsang 用的Tomcat,LInux上用的weblogic服务器, ...
- 打开Excel时提示"您尝试打开的文件**.xls的格式与文件扩展名指定的格式不一致"
问题描述: 系统安装了WPS时,Analyzer导出excel时候,会提示"您尝试打开的文件**.xls的格式与文件扩展名指定的格式不一致",这是Excel的安全问题, ...
- Excel导入工具类兼容xls和xlsx
package com.bj58.finance.platform.operation.provider.util; import org.apache.log4j.Logger; import or ...
随机推荐
- ffi模块——node调用动态链接库(.so/.dll文件)
参考资料1:[https://www.npmjs.com/package/ffi] 参考资料2:[http://imweb.io/topic/57732fbef0a5487b05f325bf] 参考资 ...
- centos 7 ip a 或ifconfig 报command not found
CentOS 7 下 ifconfig command not found 或 ip command not found 解决办法 首先查看:/sbin/ifconfig /sbin/ip 是否存 ...
- Tomcat 部署两个工程时,另一个访问出现404
tomcat下部署两个工程时,只有一个可以访问,另一个出现404错误,该如何解决 在开发新项目的时候,有时候为了省时,直接把曾经做过的项目工程A拷贝成改名为B工程,然后再在B工程上进行功能的开发, 此 ...
- POJ 2955 Brackets 区间DP 入门
dp[i][j]代表i->j区间内最多的合法括号数 if(s[i]=='('&&s[j]==')'||s[i]=='['&&s[j]==']') dp[i][j] ...
- 使用iwebshop開發實現QQ第三方登錄
$appid = "101353491"; $appkey = "df4e46ba7da52f787c6e3336d30526e4"; $redirect_ur ...
- sql server 函数详解(1)字符串函数
ASCII()函数 CHAR()函数 LEFT()函数 RIGHT()函数 LTRIM()函数 RTRIM()函数 STR()函数 字符串逆序的函数REVERSE() 计算字符串的长度函数LEN(st ...
- java 正则表达式 复习
正则表达式在日常开发中会经常的接触到,学会了正则可以更有效的对字符进行验证.拆分.替换.判断字符串是否合法等操作... 常用语法: 字符的取值范围 1.[abc] : 表示可能是a,可能是b,也可能是 ...
- docker安装笔记
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相 ...
- 初探CSS -3 语法
CSS 语法 实例 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...
- Visual Studio Code python 代码快速自动提示
1.file --> setting->设置 搜索 python 或者auto_complete setting.json { "explorer.confirmDelete&q ...