POI导入excel
前言
在做后台管理的时候经常会用到excel导入的问题,就是将excel中的内容批量导入到数据库中,正好在新项目中我也做了excel导入的功能,来分享给大家,也给自己做个记录。
核心思想
excel导入的核心思想很简单,就是读取单元格里的内容然后塞到JavaBean中,把每一个JavaBean再添加到list中再循环insert就可以了。
具体实现
前台怎么上传文件我就不在这里赘述了,我只讲后台的实现。这里我们使用poi来进行导入操作
文件导入
导入判断
上传到后台肯定得需要一系列的判断,例如文件或者其内容是否为空,上传文件格式是否正确等等
/**
* 导入判断
*
* @param mfile
* @return map
*/
public Map<String, Object> lockExcelImport(MultipartFile mfile) {
Map<String, Object> result = new HashMap<String, Object>();
//判断文件是否为空
if (mfile == null) {
result.put("result", "error");
result.put("msg", "文件不能为空!");
return result;
}
//获取文件名
String fileName = mfile.getOriginalFilename();
//验证文件名是否合格
if (!ExcelImportUtils.validateExcel(fileName)) {
result.put("result", "error");
result.put("msg", "文件必须是excel格式!");
return result;
}
//进一步判断文件内容是否为空(即判断其大小是否为0或其名称是否为null)
long size = mfile.getSize();
if (StringUtils.isEmpty(fileName) || size == 0) {
result.put("result", "error");
result.put("msg", "文件不能为空!");
return result;
}
try {
File uploadDir = new File("E:\\fileupload");
//创建一个目录 (它的路径名由当前 File 对象指定,包括任一必须的父路径。)
if (!uploadDir.exists()) uploadDir.mkdirs();
//新建一个文件
File tempFile = new File("E:\\fileupload\\" + new Date().getTime() + ".xlsx");
//初始化输入流
InputStream is = null;
//将上传的文件写入新建的文件中
mfile.transferTo(tempFile);
//根据新建的文件实例化输入流
is = new FileInputStream(tempFile);
//根据版本选择创建Workbook的方式
Workbook wb = null;
//根据文件名判断文件是2003版本还是2007版本
if (ExcelImportUtils.isExcel2007(fileName)) {
wb = new XSSFWorkbook(is);
} else {
wb = new HSSFWorkbook(is);
}
//根据excel里面的内容读取知识库信息
result.put("result", "success");
result.put("msg", readExcelValue(wb, tempFile));
} catch (IOException e) {
e.printStackTrace();
}
return result;
}
读取excel内容
进行完文件判断之后我们来进行读取excel中的内容,并将数据塞到JavaBean中,里面的每行代码我都注释的很详细,大概就是先获取到当前sheet页,之后获取行数来循环行,因为一般第一行是标题所以我们从第二行开始循环,之后获取每行的单元格,因为这里每个单元格内容都是特定的,所以我们直接获取指定单元格的值塞到对象中,再将每一个对象添加到list中去,这就是我们用来导入的数据。这里我返回的是封装好的map集合,大家直接返回map就可以
/**
* 解析Excel里面的数据
*
* @param wb
* @param tempFile
* @param userId
* @return
*/
private Map<String, Object> readExcelValue(Workbook wb, File tempFile, Integer userId) {
//返回结果
int reslutNum = 0;
//对象
List<LockHistoryEntity> lockImportList = new ArrayList<>();
//获取sheet页数
int pages = wb.getNumberOfSheets();
// 循环Excel的sheet页数,获取每个sheet表
for (int i = 0; i < pages; i++) {
// 取得工作表
Sheet sheet = wb.getSheetAt(i);
// 获取行数
int rows = sheet.getPhysicalNumberOfRows();
//循环Excel的行数,从第二行开始
for (int r = 1; r < rows; r++) {
LockHistoryEntity lockImport = new LockHistoryEntity();
//获得每一行
Row row = sheet.getRow(r);
//判断每个单元格是否为空
if (row.getCell(0) != null || row.getCell(1) != null || row.getCell(2) != null || row.getCell(3) != null) {
// 客户卡号
lockImport.setCustCode(row.getCell(0).getStringCellValue().trim());
// 客户姓名
lockImport.setCustName(row.getCell(1).getStringCellValue().trim());
}
//进行一下判断,防止将空对象添加到了list中,当然每个业务的判断条件肯定不同,因情景而仪
if (!StringUtils.isEmpty(lockImport.getCustCode())) {
// 加入数据队列
lockImportList.add(lockImport);
}
// 没有明细数据时,直接结束程序
if (lockImportList.size() == 0) {
return ServiceUtil.generateResponseMap(null, Constants.STATE_FAILED);
}
}
reslutNum = impLockHistory(lockImportList);
}
//删除上传的临时文件
if (tempFile.exists()) {
tempFile.delete();
}
return ServiceUtil.generateResponseMap(null, reslutNum > 0 ? Constants.STATE_SUCCESS : Constants.STATE_FAILED);
}
数据DB插入更新
已经到了最后一步数据插入,这里我用的是mybatis的foreach插入,直接将数据集合传过去就
POI导入excel的更多相关文章
- poi导入Excel,数字科学记数法转换
在这里分享一下使用poi 导入Excel时 把数字转换为科学记数法的解决方法: 就是使用DecimalFormat对 i 进行了格式化 结果为:
- Java 使用poi导入excel,结合xml文件进行数据验证的例子(增加了jar包)
ava 使用poi导入excel,结合xml文件进行数据验证的例子(增加了jar包) 假设现在要做一个通用的导入方法: 要求: 1.xml的只定义数据库表中的column字段,字段类型,是否非空等条件 ...
- 在java poi导入Excel通用工具类示例详解
转: 在java poi导入Excel通用工具类示例详解 更新时间:2017年09月10日 14:21:36 作者:daochuwenziyao 我要评论 这篇文章主要给大家介绍了关于在j ...
- 友好解决POI导入Excel文件行是不是为空
继 解决POI读取Excel如何判断行是不是为空 后发现了一个问题.这个是一个银行的需求,有20万个客户的资料要导入系统,但有的资料是有问题的(不能正常导入),但也有能正常导入的.现在的问题是怎么知道 ...
- java poi 导入excel
最近项目需要导入excel,网上有很多例子,自己整合记录下,兼容2003和2007,暂时没有添加图片处理功能. 所需jar包 http://pan.baidu.com/s/1sjPuWDR pack ...
- 使用POI 导入excel
引言:最近一直在接触excel的问题,网页也有很多关于POI解析excel的资料,我也简单的整理了下,有不对地方的还望及时指正,渴望与大家交流并学习. public int importExcel(F ...
- 纳税服务系统【用户模块之使用POI导入excel、导出excel】
前言 再次回到我们的用户模块上,我们发现还有两个功能没有完成: 对于将网页中的数据导入或导出到excel文件中,我们是完全没有学习过的.但是呢,在Java中操作excel是相对常用的,因此也有组件供我 ...
- 使用POI导入EXCEL报java.lang.IncompatibleClassChangeError
使用POI导入xls格式的excel报java.lang.IncompatibleClassChangeError异常,而导入xlsx正常. oracle.apps.fnd.framework.OAE ...
- POI导入excel文件2
POI上传到服务器读取excel文件1中已经介绍了上传文件和导入excel所有的内容http://www.cnblogs.com/fxwl/p/5896893.html , 本文中只是单单读取本地文件 ...
- 使用POI导入Excel异常Cannot get a text value from a numeric cell 解决
POI操作Excel时因为Excel数据Cell有不同的类型,会出现Cannot get a text value from a numeric cell的异常错误. 异常原因:Excel数据Cell ...
随机推荐
- 搭建CentOS 7本地源仓库
CentOS 7离线包及其依赖 推荐使用yumdownloader --resolve --destdir=path python-pip,--resolve下载所有依赖,--destdir指定软件包 ...
- 如何在VMware12中安装centos6.7系统
一.安装虚拟机,步骤如下: 1.安装好VMware12软件(略过),安装完后点击创建新的虚拟机 2.选择自定义类型安装 3.点击下一步 4.选择稍后安装操作系统,点击[下一步]. 5.客户机操作系统选 ...
- 23 | 知其然知其所以然:聊聊API自动化测试框架的前世今生
- Web安全深度剖析
Web安全深度剖析 链接:https://pan.baidu.com/s/15NulgWNzQ2JPCdn9q1jE-g 提取码:6y83 Web安全深度剖析>总结了当前流行的高危漏洞的形 ...
- python的输入和输出
基本输出 python中的输出使用关键字--print,与python2不同的是,python3的输出后面必须要加括号,示例如下: python3.0以上输出: python2.0以上的输出: 格式化 ...
- ORACLE导入数据库详细步骤
登录PLSQL 点击然后打开命令窗口执行命令 创建表空间(红色字体是你需要创建表空间的地址,蓝色的是表空间大小) create temporary tablespace ZJY_TEMP tempfi ...
- Spring Cloud Alibaba | Nacos服务中心初探
目录 Spring Cloud Alibaba | Nacos服务中心初探 1. 什么是Nacos? 1.1 Nacos 1.0 1.2 Nacos 2.0 2. Nacos 架构及概念 2.1 服务 ...
- C++内存泄漏及检测工具详解
#include "stdafx.h" #ifdef _DEBUG #define DEBUG_CLIENTBLOCK new( _CLIENT_BLOCK, __FILE__, ...
- matlab考试重点详解
此帖是根据期末考试复习重点补充完成, 由于使用word编辑引用图片和链接略有不便, 所以开此贴供复习及学习使用.侵删 复习要点 第一章 Matlab的基本概念,名称的来源,基本功能,帮助的使用方法 1 ...
- 个人永久性免费-Excel催化剂功能第50波-批量打印、导出PDF、双面打印功能
在倡导无纸化办公的今天,是否打印是一个碍眼的功能呢,某些时候的确是,但对于数据的留存,在现在鼓吹区块链技术的今天,仍然不失它的核心价值,数据报表.单据打印出来留存,仍然是一种不可或缺的数据存档和防篡改 ...