JavaExcel工具类(兼容xls和xlsx)

最近用上了导入excel表格处理保存到后台数据库的功能!利用的是org.apache.poi进行处理

示例代码:

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;import java.io.IOException;
import java.io.InputStream;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;/*** Created by LiYangYong on 2022/02/06*/
public class ExcelUtil {private final static String excel2003L =".xls";    //2003- 版本的excelprivate final static String excel2007U =".xlsx";   //2007+ 版本的excel/*** 描述:获取IO流中的数据,组装成List<List<Object>>对象* @param in,fileName* @return* @throws IOException*/public static  List<List<Object>> getBankListByExcel(InputStream in, String fileName) throws Exception{List<List<Object>> list = null;//创建Excel工作薄Workbook work = getWorkbook(in,fileName);if(null == work){throw new Exception("创建Excel工作薄为空!");}Sheet sheet = null;Row row = null;Cell cell = null;list = new ArrayList<List<Object>>();//遍历Excel中所有的sheetfor (int i = 0; i < work.getNumberOfSheets(); i++) {sheet = work.getSheetAt(i);if(sheet==null){continue;}//遍历当前sheet中的所有行for (int j = sheet.getFirstRowNum()+1; j < sheet.getLastRowNum()+1; j++) {row = sheet.getRow(j);if(row==null){continue;}//  if(row==null||row.getFirstCellNum()==j){continue;}//遍历所有的列List<Object> li = new ArrayList<Object>();for (int y = row.getFirstCellNum(); y < row.getLastCellNum(); y++) {cell = row.getCell(y);li.add(getCellValue(cell));}list.add(li);}}//work.close();return list;}/*** 描述:根据文件后缀,自适应上传文件的版本* @param inStr,fileName* @return* @throws Exception*/public static Workbook getWorkbook(InputStream inStr,String fileName) throws Exception{Workbook wb = null;String fileType = fileName.substring(fileName.lastIndexOf("."));if(excel2003L.equals(fileType)){wb = new HSSFWorkbook(inStr);  //2003-}else if(excel2007U.equals(fileType)){wb = new XSSFWorkbook(inStr);  //2007+}else{throw new Exception("解析的文件格式有误!");}return wb;}/*** 描述:对表格中数值进行格式化* @param cell* @return*/public static Object getCellValue2(Cell cell){Object value = null;DecimalFormat df = new DecimalFormat("0");  //格式化number String字符SimpleDateFormat sdf = new SimpleDateFormat("yyy-MM-dd");  //日期格式化DecimalFormat df2 = new DecimalFormat("0.00");  //格式化数字switch (cell.getCellType()) {case Cell.CELL_TYPE_STRING:value = cell.getRichStringCellValue().getString();break;case Cell.CELL_TYPE_NUMERIC:if("General".equals(cell.getCellStyle().getDataFormatString())){value = df.format(cell.getNumericCellValue());}else if("m/d/yy".equals(cell.getCellStyle().getDataFormatString())){value = sdf.format(cell.getDateCellValue());}else{value = df2.format(cell.getNumericCellValue());}break;case Cell.CELL_TYPE_BOOLEAN:value = cell.getBooleanCellValue();break;case Cell.CELL_TYPE_BLANK:value = "";break;default:break;}return value;}@SuppressWarnings("deprecation")public static String getCellValue(Cell cell) {if (cell == null)return "";if (cell.getCellType() == Cell.CELL_TYPE_STRING) {return cell.getStringCellValue();} else if (cell.getCellType() == Cell.CELL_TYPE_BOOLEAN) {return String.valueOf(cell.getBooleanCellValue());} else if (cell.getCellType() == Cell.CELL_TYPE_FORMULA) {return cell.getCellFormula();} else if (cell.getCellType() == Cell.CELL_TYPE_NUMERIC) {short format = cell.getCellStyle().getDataFormat();System.out.println("format:"+format+";;;;;value:"+cell.getNumericCellValue());SimpleDateFormat sdf = null;if (format == 14 || format == 31 || format == 57 || format == 58|| (176<=format && format<=178) || (182<=format && format<=196)|| (210<=format && format<=213) || (208==format ) ) { // 日期sdf = new SimpleDateFormat("yyyy-MM-dd");} else if (format == 20 || format == 32 || format==183 || (200<=format && format<=209) ) { // 时间sdf = new SimpleDateFormat("HH:mm");} else { // 不是日期格式return String.valueOf(cell.getNumericCellValue());}double value = cell.getNumericCellValue();Date date = DateUtil.getJavaDate(value);if(date==null || "".equals(date)){return "";}String result="";try {result = sdf.format(date);} catch (Exception e) {e.printStackTrace();return "";}return result;}return "";}
}

大家点赞、收藏、关注、评论啦 、查看下方👇🏻👇🏻👇🏻微信公众号获取👇🏻👇🏻👇🏻

打卡 文章 更新 186/  365天

专栏推荐阅读:

java项目精品实战案例《100套》

web前端期末大作业网页实战《100套》

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/561783.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Springboot@PathVariable注解使用--请求路径占位符

常用请求方式&#xff1a;http://localhost:10003/railway-api/base/stEstimate/info?id1 rest请求方式&#xff1a; 传统RequestParam是从request 中接收请求&#xff01;而 PathVariable 是从一个URI模板里面来填充 拿一个例子来说吧 RequestMapping(value "/info/{…

基于JavaSpringMVC+Mybatis+Jquery高校毕业设计管理系统设计和实现

&#x1f345; 作者主页&#xff1a;Java李杨勇 &#x1f345; 简介&#xff1a;Java领域优质创作者&#x1f3c6;、【java李杨勇】公号作者✌ 简历模板、学习资料、面试题库【关注我&#xff0c;都给你】 &#x1f345;文末获取源码联系&#x1f345; 前言&#xff1a; 随着…

RSA加密:Web前端登录账户密码加密传输

一般在做系统时候对安全性要求比较高&#xff0c;现在通常选择https协议来进行数据传输。很多情况下一般的javaweb网站&#xff0c;如果安全要求不是很高的话&#xff0c;用https协议就可以了。在这种情况下&#xff0c;密码的明文传输显然是不合适的&#xff0c;因为请求如果在…

java参数校验:ValidatorUtils校验框架工具类的使用

&#x1f345; 作者主页&#xff1a;Java李杨勇 &#x1f345; 简介&#xff1a;Java领域优质创作者&#x1f3c6;、【java李杨勇】公号作者✌ 简历模板、学习资料、面试题库【关注我&#xff0c;都给你】 在日常开发中经常对参数进行校验、可以使用Validator&#xff0c;一般…

Springboot项目启动:报错The last packet sent successfully to the server was 0 milliseconds ago

解决方法&#xff1a;修改MySQL数据库连接后面未为如下即可 ?useSSLfalse&useUnicodetrue&characterEncodingutf-8&useLegacyDatetimeCodefalse&serverTimezoneAsia/Shanghai

IDEA编译运行Springboot+vue项目卡死,一直building和copying resources

是因为我把node_modules也放在了resource目录下、编译的时候target文件目录过大或一直递归循环、导致卡死一直在copying resources当中&#xff0c;在IDEA中设置一下忽略node_modules文件夹即可。

IDEA: .java文件和.class不一致

今天在IDEA中编写代码的时候无意发现自己编写的java文件和即时编辑后的class文件不一致、对项目clean以及重启idea都还是没有解决。最后删除target即可解决。

基于Java+Jsp+SpringMVC漫威手办商城系统设计和实现

&#x1f345; 作者简介&#xff1a;CSDN特邀作者✌、java领域优质创作者&#x1f4aa; &#x1f345;关注公众号【java李杨勇】 简历模板、学习资料、面试题库等都给你 &#x1f345;文末获取源码联系&#x1f345; 一、前言介绍&#xff1a; 随着社会的快速发展&#xff0c;…

基于Java+jquery+SpringMVC校园网站平台设计和实现

&#x1f345; 作者简介&#xff1a;CSDN特邀作者✌、java领域优质创作者&#x1f4aa; &#x1f345;关注公众号【java李杨勇】 简历模板、学习资料、面试题库等都给你 &#x1f345;文末获取源码联系&#x1f345; 目录 一、前言介绍&#xff1a; 二、功能设计&#xff1…

Springboot+Element ui Vue图片上传回显

最近个人自己做前后端分离项目、遇到了图片上传、简单记录一下。 前端vue element UI部分需要提交的表单数据&#xff1a; <el-col :span"24"> <el-form-item class"upload" v-if"type!info && !ro.touxiang" label"头像…

基于Java+SpringBoot+vue+element等动物救助平台设计和实现

&#x1f345; 作者简介&#xff1a;CSDN特邀作者✌、java领域优质创作者&#x1f4aa; &#x1f345;关注公众号【java李杨勇】 简历模板、学习资料、面试题库等都给你 &#x1f345;文末获取源码联系&#x1f345; &#x1f345;新星计划第三季【Java】赛道的报名入口&…

java.lang.NoSuchFieldError: No instance field

找不到该方法 是因为大意少写了 Autowired JavaBean中注解

基于Java+SpringMvc+vue+element实现上海汽车博物馆平台

&#x1f345; 作者简介&#xff1a;CSDN特邀作者✌、博客专家✌、java领域优质创作者&#x1f4aa; &#x1f345;关注公众号【java李杨勇】 简历模板、学习资料、面试题库等都给你&#x1f4aa; &#x1f345;文末获取源码联系&#x1f345; &#x1f345;新星计划第三季【J…

IDEA: vue文件 File is read-only

今天有个同学问我是vue文件设置了什么权限吗&#xff1f;文件只读操作。 解决方法;这是因为文件主动或者被动被锁定了&#xff0c;选择相应文件&#xff0c;点击File---Make File Writable处理解决即可。

基于Java+SpringBoot+vue+element实现毕业就业招聘系统

&#x1f345; 作者简介&#xff1a;CSDN特邀作者✌、博客专家✌、java领域优质创作者&#x1f4aa; &#x1f345;关注公众号【java李阳勇】 简历模板、学习资料、面试题库等都给你&#x1f4aa; &#x1f345;文末获取联系&#x1f345;精彩专栏推荐订阅&#x1f447;&#…

基于Java+SpringBoot+vue+element实现扶贫助农政策平台系统

&#x1f345; 作者简介&#xff1a;CSDN特邀作者✌、博客专家✌、java领域优质创作者&#x1f4aa; &#x1f345;关注公众号【java李杨勇】 简历模板、学习资料、面试题库等都给你&#x1f4aa; &#x1f345;新星计划第三季【Java】赛道的报名入口&#xff01;下一个新星就…

基于Java+SpringBoot+vue+element实现前后端分离玩具商城系统

&#x1f345; 作者简介&#xff1a;CSDN特邀作者✌、博客专家✌、java领域优质创作者&#x1f4aa; &#x1f345;关注公众号【java李杨勇】 简历模板、学习资料、面试题库等都给你&#x1f4aa; &#x1f345;文末获取源码联系&#x1f345; &#x1f345;新星计划第三季【J…

Java 结构化数据处理开源库 SPL

前言介绍&#xff1a; 现代Java应用架构越来越强调数据存储和处理分离&#xff0c;以获得更好的可维护性、可扩展性以及可移植性&#xff0c;比如火热的微服务就是一种典型。这种架构通常要求业务逻辑要在Java程序中实现&#xff0c;而不是像传统应用架构中放在数据库中。 应用…

IDEA项目 let报错爆红

用idea编写代码的时候 let报错爆红 解决方法&#xff1a;修改版本 设置后就ok了

Mysql5换成Mysql8之后报错java.lang.ClassNotFoundException: com.mysql.jdbc.driver的问题解决

排除了依赖和版本等问题、最终解决方法为 在链接后面加上如下设置 useUnicodetrue&characterEncodingutf-8&useJDBCCompliantTimezoneShifttrue&useLegacyDatetimeCodefalse&serverTimezoneGMT%2B8