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 ...
随机推荐
- 为什么现在这么多人开始学习Python?
近几年Python编程语言在国内引起不小的轰动,有超越JAVA之势,本来在美国这个编程语言就是最火的,应用的非常非常的广泛,而Python的整体语言难度来讲又比JAVA简单的很多.尤其在运维的应用中非 ...
- eclipse的安装与使用方法
eclipse的安装与使用方法: eclipse是Java编程利器,工欲善其事必先利其器.下面我们来说说eclipse的安装与使用: 安装分三步: 第一步:安装eclipse 1.官网下载eclips ...
- 最新ubuntu搭建公网个人邮件服务器(基于postfix,dovecot,mysql)
最近做了一个应用,需要用邮件发通知,但是免费的邮箱每天发信数量是有限制的,所以呢就想着搭建一个自己的邮件服务器,能够实现邮件的发送和接收即可,其中大概花了一个星期找资料,测试,终于成功了,写个教程 ...
- IDEA中Maven依赖包下载不了的问题解决方案汇总
第一种方案: 第二种方案:下面的几个不要选择. 第三种方案:可能是某一个 dependency 依赖无法下载,导致整个项目都报错 打开具体的报错的maven项目的pom.xml.试着去删除一些 dep ...
- 6.秋招复习简单整理之请你谈谈JDBC的反射,以及它的作用?
通过反射com.mysql.jdbc.Driver类,实例化该类时会调用该类的静态代码块,该代码块会去java的DriverManager类中注册自己,DriverManager管理所有已注册的驱动类 ...
- 使用cmd打开磁盘目录和文件
例如: 1.进入e盘 2.查看E盘下所有文件 3.进入指定文件夹
- 使用GDAL实现DEM的地貌晕渲图(二)
1. 问题 之前我在<使用GDAL实现DEM的地貌晕渲图(一)>这篇文章里面讲述了DEM晕渲图的生成原理与实现,大体上来讲是通过计算DEM格网点的法向量与日照方向的的夹角,来确定该格网点的 ...
- python 中_init_函数以及参数self
1)class类包含: 类的属性:类中所涉及的变量 类的方法:类中函数 2)_init_函数(方法) 1.首先说一下,带有两个下划线开头的函数是声明该属性为私有,不能在类地外部被使用或直接访问. 2. ...
- Excel催化剂开源第4波-ClickOnce部署要点之导入数字证书及创建EXCEL信任文件夹
Excel催化刘插件使用Clickonce的部署方式发布插件,以满足用户使用插件过程中,需要对插件进行功能升级时,可以无痛地自动更新推送新版本.但Clickonce部署,对用户环境有较大的要求,前期首 ...
- ieda使用 在jsp页面中,有时候会出现不能智能显示方法 idea pageContext.setAttribute
idea使用,出现问题记录: 就比如在 pageContext.setAttribute("user",u);这句打pageContext会智能提示, 但是后面的setAttrib ...