Java实现导入Excel文件
一.配置文件名称、路径、内容:
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value="utf-8"></property>
<property name="maxUploadSize" value="104857600"></property><!-- 最大上传文件大小:100M -->
<property name="maxInMemorySize" value="10240"></property>
</bean>
二.controller
@RequestMapping(value = "/importAccountManager")
@ResponseBody
public ModelAndView importAccountManager(HttpServletRequest request, HttpServletResponse response,
@RequestParam("file") CommonsMultipartFile file) {
ModelAndView mav = new ModelAndView(new MappingJackson2JsonView());
try (InputStream inputXls = file.getInputStream();
InputStream inputXML = new BufferedInputStream(getClass().getClassLoader().getResourceAsStream(ACCOUNT_TEMPLATE_PATH));) {
XLSReader mainReader = ReaderBuilder.buildFromXML(inputXML);
List<AccountManagerModel> dataList = new ArrayList<>();
Map<String, Object> params = new HashMap<>();
params.put("dataList", dataList);
mainReader.read(inputXls, params);
String message = accountManagerService.importAccountManager(dataList);
if(StringUtils.isNotBlank(message)) {
mav.addObject("success", false);
} else {
mav.addObject("success", true);
}
mav.addObject("message", message);
} catch (Throwable e) {
LOGGER.error("importAccountManager causes inner exception:", e);
mav.addObject("success", false);
mav.addObject("message", e.getMessage());
}
return mav;
}
三.service
//serviceImpl
@Override
public String importAccountManager(List<AccountManagerModel> accountList) throws Exception {
List<OrgModel> orgList = orgMapper.queryOrg();
String message = validate(accountList, orgList);
if(message == null) {
for(AccountManagerModel account : accountList) {
String consNo = account.getConsNo();
AccountManagerModel oldAccount = accountManagerMapper.queryByConsNo(consNo);
if(oldAccount == null) {
insertAccountManager(account);
} else {
editAccountManager(account, oldAccount);
}
}
}
return message;
}
//interface
/**
* 导入客户数据
*
* @param accountList
* @return
* @throws Exception
*/
public String importAccountManager(List<AccountManagerModel> accountList) throws Exception;
四.mapper
//interface
/**
* 通过客户号查询企业
*
* @param consNo
* @return
* @throws throws Exception
*/
public AccountManagerModel queryByConsNo(String consNo) throws Exception;
//mapper映射xml
<select id="queryByConsNo" parameterType="java.lang.String" resultMap="AccountManagerResultMap">
select
a.cons_id,
a.cons_no,
a.cons_name,
a.cons_address,
a.legal_person,
a.legal_person_phone,
a.bill_person,
a.bill_person_phone,
a.electric_person,
a.electric_person_phone,
a.entrusted_person,
a.entrusted_person_phone,
a.cons_state,
a.org_no,
b.org_name
from be_cons_info a, o_org b
where a.org_no = b.org_no
and a.cons_no = #{consNo}
</select>
五.Html
<div class="tool_wrapper">
<button class="ui-btn ui-btn-primary" onclick="addAccountManager();">新增</button>
<button class="ui-btn ui-btn-primary left20" onclick="editAccountManager();">修改</button>
<!-- <button class="ui-btn ui-btn-primary left20" onclick="cancelAccountManager();">注销</button> -->
<button class="ui-btn ui-btn-primary left20 fileinput-button">
<span>导入Excel</span>
<input id="fileupload" type="file" name="file" accept="application/vnd.ms-excel">
</button>
<button class="ui-btn ui-btn-primary left20" onclick="exportXls()">导出Excel</button>
<button class="ui-btn ui-btn-primary left20" onclick="downloadXlsTemplate()">下载模板</button>
</div>
六.js
function bindFileUploadEvent() {
$('#fileupload').fileupload({
url: basePath + 'accountManager/importAccountManager',
type: 'post',
dataType: 'json',
beforeSend: function(xhr){
xhr.setRequestHeader(header, token);
},
send: function(e, data) {
var file = data.files[0];
var fileName = file.name;
var fileSize = file.size;
var errorMsg = "请选择Excel文件!";
var pass = validateFileName(fileName, ".xls");
if(pass && fileSize >= 10485760) {
pass = false;
errorMsg = "选择的Excel文件须小于10M!";
}
if(!pass) {
$('#fileupload').val('');
errorDialog(errorMsg);
} else {
if(parent.progress) {
parent.progress.show();
}
}
return pass;
},
done: function(e, data) {
var result = data.result;
if(result.success) {
queryAccountManager();
succDialog("客户数据导入成功!");
} else {
errorDialog(result.message);
}
},
fail: function(e, data) {
if(data.textStatus != null) {
errorDialog("系统发生故障,请联系系统管理员或稍后重试!");
}
},
always: function(e, data) {
if(parent.progress) {
parent.progress.hide();
}
}
});
}
Java实现导入Excel文件的更多相关文章
- java如何导入Excel文件
Java使用POI导入Excel文件,操作起来比较简单,支持xlsx格式. 下载POI资源包 从官网https://poi.apache.org/下载POI,笔者选择的是版本是3.17,下载后文件名是 ...
- Java解析导入Excel文件后台代码实现
使用MultipartFile上传Excel文件后端代码实现:(springmvc下的spring-webmvc (MultipartFile )上传) 由于POST一个包含文件上传的Form会以mu ...
- Java POI导入Excel文件
今天在公司需要做个导入Excel文件的功能,所以研究了一下,参考网上的一些资料总算是做出来了,在此记录一下防止以后忘记怎么弄. 本人用的是poi3.8,所以需要的JAR包如下: poi-3.8.jar ...
- Java jxl导入excel文件,导入的数字、身份证号码、手机号变成了科学计数法,解决方案
原文出自:https://blog.csdn.net/seesun2012 这是一个execl文件导入数据库操作,使用jxl解析execl导入数据库过程出现了科学计数法,与想要导入的数据不匹配,以下是 ...
- .Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) 通过MVC控制器导出导入Excel文件(可用于java SSH架构)
.Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) [原文地址] 通过MVC控制器导出导入Excel文件(可用于java SSH架构) public cl ...
- java后端导入excel模板和导入excel文件去读数据
模板转载地址:https://www.cnblogs.com/zhangyangtao/p/9802948.html 直接上代码(我是基于ssm写的demo,导入文件目前只能读取.xls后缀的exce ...
- springMVC(5)---导入excel文件数据到数据库
springMVC(5)---导入excel文件数据到数据库 上一篇文章写了从数据库导出数据到excel文件,这篇文章悄悄相反,写的是导入excel文件数据到数据库.上一篇链接:springMVC(4 ...
- 利用kettle组件导入excel文件到数据库
利用kettle组件导入excel文件到数据库 1. 实现目标 把excel文件内容导入到目标表中:然后用java调用kettle的转换.excel文件的内容仅仅有两列,示比例如以下: wat ...
- java上传excel文件及解析
java上传excel文件及解析 CreateTime--2018年3月5日16:25:14 Author:Marydon 一.准备工作 1.1 文件上传插件:swfupload: 1.2 文件上 ...
随机推荐
- 目录已存在导致Jenkins项目构建失败的解决方法
Jenkins中的项目在下载源代码时,如果Working Directory中存在未加入版本控制的文件或者目录已经存在于SVN库中,会导致更新失败,整个构建终止,解决方法是将SVN的检出策略由&quo ...
- 从零开始的Java RASP实现(二)
目录 2 RASP-demo 2.1 类加载机制 双亲委派 BootStrap ClassLoader 2.2 Instrumentation介绍 Instrumentation类中常用方法 Inst ...
- 如何请求一个需要登陆才能访问的接口(基于cookie)---apipost
在后台在开发.调试接口时,常常会遇到需要登陆才能请求的接口. 比如:获取登陆用户的收藏列表,此时,我们就需要模拟登陆状态进行接口调试了.如图: 今天,我们讲解利用ApiPost的环境变量,解决这种需要 ...
- Java Swing 空布局
Swing 空布局 试了盒布局,说实话不太会用,很多地方都没法更加的细节,又翻了翻资料,知道了还有一个空布局,一看,真不错,很适合我这种菜鸡 用坐标就可以完成界面的布局,不错 话不多说,直接代码 pa ...
- Git(9)-- 远程仓库的使用
@ 目录 1.查看远程仓库:git remote 2.添加远程仓库:git remote add 3.从远程仓库中抓取与拉取:git fetch和 git pull 4.推送到远程仓库:git pus ...
- Django ORM记录的增删改查结合web端
模版语法分配变量 在views.py文件中定义一个视图函数show_data: def show_data(request): # 定义一个字典 并将它展示在前端HTML文件 user_dic = { ...
- Docker运行PostgreSQL
docker-compose.yml version: '3.1' services: db: image: postgres restart: always ports: - 5432:5432 e ...
- 简单实现 nodejs koa2 mysql 增删改查 制作接口
1.首先 在电脑上安装 nodejs (此处略过) 2.全局安装 koa2 (这里使用的淘宝镜像cnpm,有兴趣的同学可以自行搜索下) cnpm install koa-generator -g 3. ...
- COM组件的使用方法
https://prismlibrary.com/docs/wpf/converting-from-7.html Requirement: 1.创建myCom.dll,该COM只有一个组件,两个接口I ...
- 在ASP.NET Core调用WebService
一.前言 现实生产中,有一些比较老的系统对外提供的接口都是WebService形式的,如果是使用.NET Framework创建的项目调用WebService非常方便,网上有很多代码示例,这里不在讲解 ...