java后端导入excel将数据写入数据库
参考:https://www.cnblogs.com/hanfeihanfei/p/7079210.html
@RequestMapping("/importExcel.do")
public void import2(String xlsPath) throws IOException, BiffException {
// 导入已存在的Excel文件,获得只读的工作薄对象
FileInputStream fis = new FileInputStream(xlsPath);
Workbook wk = Workbook.getWorkbook(fis);
// 获取第一张Sheet表
Sheet sheet = wk.getSheet(0);
// 获取总行数
int rowNum = sheet.getRows();
System.out.println("插入总行数:"+rowNum);
// 从数据行开始迭代每一行
for (int i = 0; i < rowNum; i++) {
//先判断插入的数据是否和数据库的数据重复
if(userService.findUser(sheet.getCell(0, i).getContents())>0) {
continue;
}
User u = new User();
// getCell(column,row),表示取得指定列指定行的单元格(Cell)
// getContents()获取单元格的内容,返回字符串数据。适用于字符型数据的单元格
// 使用实体类封装单元格数据
u.setName(sheet.getCell(0, i).getContents());
u.setAge(sheet.getCell(1, i).getContents());
u.setNickName(sheet.getCell(2, i).getContents());
userService.saveUser(u);
System.out.println("成功插入:"+sheet.getCell(0, i).getContents());
/*// 判断单元格的类型,单元格主要类型LABEL、NUMBER、DATE
if (sheet.getCell(2, i).getType == CellType.NUMBER) {
// 转化为数值型单元格
NumberCell numCell = (NumberCell) sheet.getCell(2, i);
// NumberCell的getValue()方法取得单元格的数值型数据
info.setRscore(numCell.getValue());
}
if (sheet.getCell(3, i).getType == CellType.NUMBER) {
NumberCell numCell = (NumberCell) sheet.getCell(3, i);
info.setRscore(numCell.getValue);
}
if (sheet.getCell(4, i).getType == CellType.DATE) {
DateCell dateCell = (DateCell) sheet.getCell(4, i);
// DateCell的getDate()方法取得单元格的日期型数据
info.setDate(dateCell.getDate());
}*/
}
fis.close();
wk.close();
}
注解都比较详细了
前端代码(ie8和chrome前端获取的路径会出问题)
<form>
<input type="file" id="fileName" name="xlsPath" /> <input
type="button" id="btn" value="提交">
</form>
$("#btn").click(function() {
var xlsPath = document.getElementById("fileName").value;
/* var path=getPath(xlsPath);
alert(path); */
$.ajax({
"url" : "${pageContext.request.contextPath}/importExcel.do",
"type" : "GET",
"data" : "xlsPath=" + xlsPath,
"dataType" : "json",
"success" : function(res) {
if (res.state == 1) {
alert(message);
} else {
alert(message);
}
}
});
});
可以直接用
java后端导入excel将数据写入数据库的更多相关文章
- springMVC(5)---导入excel文件数据到数据库
springMVC(5)---导入excel文件数据到数据库 上一篇文章写了从数据库导出数据到excel文件,这篇文章悄悄相反,写的是导入excel文件数据到数据库.上一篇链接:springMVC(4 ...
- java后端导入excel模板和导入excel文件去读数据
模板转载地址:https://www.cnblogs.com/zhangyangtao/p/9802948.html 直接上代码(我是基于ssm写的demo,导入文件目前只能读取.xls后缀的exce ...
- poi导入excel表格数据到数据库的时候,对出生日期的校验
出生日期格式为8位数字的字符串 如:yyyyMMdd 规则:yyyy大于1900并小于当前时间,月.日 按日期规则校验 //解决读过来的字符串显示为科学计数法问题 BigDecimal bd = ne ...
- mysql 导入excel文件数据到数据库
load data local infile 'C:/Users/Administrator/Documents/gaunai2.csv' into table newtable (c1,c2) fi ...
- 在java poi导入Excel通用工具类示例详解
转: 在java poi导入Excel通用工具类示例详解 更新时间:2017年09月10日 14:21:36 作者:daochuwenziyao 我要评论 这篇文章主要给大家介绍了关于在j ...
- java后端导出excel
最近工作中需要导出excel.这次机智一点做个笔记,顺便写了一个比较通用的工具类.自然目前不能生成java实体类属性嵌套多次的这种没办法导出了,后续有需要的时候我再改改. 首先,java后端导出exc ...
- 《项目经验》--通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来的Json数据写入数据库表中
先看一下我要实现的功能界面: 这个界面的功能在图中已有展现,课程分配(教师教授哪门课程)在之前的页面中已做好.这个页面主要实现的是授课,即给老师教授的课程分配学生.此页面实现功能的步骤已在页面 ...
- 通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来的Json数据写入数据库表中
摘自:http://blog.csdn.net/mazhaojuan/article/details/8592015 通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来 ...
- 图形数据写入数据库,Filletream
图形数据写入数据库 用FileStream对象读模式打开图形文件 Dim 文件对象 As New FileStream(图形文件名, FileMode.Open, FileAccess.Read) 定 ...
随机推荐
- input.text文件提示效果
<div class="search"><input type="text" value="Seach Products" ...
- rbenv安装本地ruby安装包
cd .rbenv mkdir cache #把安装包拷进cache cd cache rbenv install 版本号
- 744. Find Smallest Letter Greater Than Target
俩方法都是用二分查找,一个调库,一个自己写而已. 方法一,调库 static int wing=[]() { std::ios::sync_with_stdio(false); cin.tie(NUL ...
- 2018.12.18 bzoj2242: [SDOI2011]计算器(数论)
传送门 数论基础题. 对于第一种情况用快速幂,第二种用exgcdexgcdexgcd,第三种用bsgsbsgsbsgs 于是自己瞎yyyyyy了一个bsgsbsgsbsgs的板子(不知道是不是数据水了 ...
- 2018.10.30 uoj#273. 【清华集训2016】你的生命已如风中残烛(组合数学)
传送门 组合数学妙题. 我们把这mmm个数都减去111. 然后出牌的地方就变成了−1-1−1. 然后发现求出每个位置的前缀和之后全部都是非负数. 考虑在最后加入一个−1-1−1构成一个m+1m+1m+ ...
- 牛客训练四:Applese 的回文串(思维)
题目链接:传送门 思路:插入不同的字符与删除不同的字符相同,所以每次判断到不同位置时将这个字符删除然后判断是否为回文串即可, 如果一开始就是回文串,那么答案也是yes. #include<ios ...
- Java基础语法学习知识
基础概念 标识符1.由字母,数字,下划线,美元符组成2.首字母不能是数字3.不能是关键字和保留字4.能反映其作用 关键字1.有特定含义2.用于特定地方3.用来命名标识符 常量1.程序执行时值不变的量2 ...
- FASTDFS 安装与开发
FASTDFS介绍 FastDFS开源地址:https://github.com/happyfish100 简介 FastDFS 是一个开源的高性能分布式文件系统(DFS). 它的主要功能包括:文件存 ...
- Le Chapitre VII
Le cinquième jour, toujours grâce au mouton, ce secrèt de la vie du petit prince me fut révélé. Il m ...
- Github上下载某一个文件夹
1.安装svn sudo apt-get install subversion 2.修改下载文件夹的链接 例如,https://github.com/a***b/learn/tree/master/m ...