导入解析excel小结
导入解析excel小结
控制器例子:
一. 解析excel内容插入到数据库
Vm:
<form id=’form_file’ method=’post’ enctype=’multipart/form-data’>
<input id="uploadFile" type="file" name='uploadFile' />
<a href=’javascirpt(void0)’ onclick=’resolv();’>解析</a>
</form>
注意:解析按钮必须是<a>标签,如果换成button,用公司的表单提交则会出错:提示不是MultipartFile请求.
Js:$(‘#form_file’).bupform(
dataType:’json’,
onSubmit:function(){return true;},//return false则会阻止表单提交
success:function(data){
//成功后的回调函数
}
);
Controller:
处理请求的方法参数用(MultipartFile uploadFile)类型接收
解析excel内容步骤:
- 通过传过来的uploadFile拿到流:
a) ImputStream is = uploadFile.getInputStraam();
- 创建poiSysteam:
fs = new POIFSFileSystem(is);
- 创建workbook
a) wb = new HSSFWorkbook(fs);
1. sheet = wb.getSheetAt(0);//拿到excel的第一个sheet
2. 得到总行数:int rowNum = sheet.getLastRowNum();
3. 得到excel的某一行
a) HSSFRow row = sheet.getRow(0);//得到第0行 也就是excel的标题
- 得到一行里的某个单元格:
a) HSSFCell cell = row.getCell(0);
b) 通过HSSFCell 单元格类型拿到单元格的数据
- 获取单元格的type: type = cell.getCellType();
- HSSFCell.CELL_TYPE_FORMUL数字类型:cell.getNumericCellValue();
- HSSFCell.CELL_TYPE_STRING:类型cell.getRichStringCellValue();
- HSSFCell.CELL_TYPE_FORMULA:类型
If(HSSFDateUtil.isCellDateFormatted(cell)){
Date date = cell.getDateCellValue();
}
- 身份证号避免科学计数法:
DecimalFormat df = new DecimalFormat("0");
cellvalue = df.format(cell.getNumericCellValue());
- 如果cell==null 的话,就给一个’’空字符串给他
7. 每一行的数据,可以自己定义一个类来保存,类中的字段于行里面的每一列对应
也可以用一个Map<Integer,String>-à <行号,行里面的内容>
二. 下载项目中的资源
- 方式一:
<a href='/res/excel/广东省补贴金额表.xls'>下载excel文档模板:</a>
- 方式二:
Vm:<a href=’download.do?filename=广东省补贴金额表.xls’ ></a>
Controller:
处理请求的方法:
public void download(HttpServletResponse response,String filename){
a) 设置文件的MIME类型
response.setContentType(getServletContext().getMimeType(filename));
b) 拿到绝对路径
String fullFileName = “/res/excel/”+filename;
c) response.setHeader("Content-Disposition", "attachment; filename="+ new String(filename.getBytes("GBK"), "ISO8859-1"));
d) InputStream in = new FileInputStream(fullFileName);
e) BufferedInputStream bis = new BufferedInputStream(in);
f) BufferedOutputStreamout=new BufferedOutputStream(response.getOutputStream());
int b;
While(b=(bis.read()!=-1){
Out.write(b);
}
In.close();
Out.flush();
Out.close();
导入解析excel小结的更多相关文章
- EasyPOI导入导出Excel
EasyPOI工具可以方便的写出Excel导出,Excel模板导出,Excel导入,Word模板导出,通过简单的注解和模板 导入maven依赖 <dependency> <group ...
- oracle xmltype导入并解析Excel数据--前言
通常,很多的时候,我们需要导入Excel数据到系统中,但是Excel数据需要我们去各种校验,比如身份证校验,手机号码校验等等. 校验失败的数据,提供Excel导出错误原因,提示给用户. 如此,如果校验 ...
- nodejs:导出Excel和解析导入的Excel
用的是koa2框架,但好好处理一下,用express框架也是可以的.导出的Excel是xlsx的格式,解析导入Excel的有xlsx和csv格式.通常导入Excel是要上传的,然后获取文件的路径,这里 ...
- POI完美解析Excel数据到对象集合中(可用于将EXCEL数据导入到数据库)
实现思路: 1.获取WorkBook对象,在这里使用WorkbookFactory.create(is); // 这种方式解析Excel.2003/2007/2010都没问题: 2.对行数据进行解析 ...
- C#用Infragistics 导入导出Excel(一)
最近项目中有数据的导入导出Excel的需求,这里做简单整理. 公司用的是Infragistics的产品,付费,不需要本地安装Office. 有需要的朋友可以下载 Infragistics.2013.2 ...
- Java基于注解和反射导入导出Excel
代码地址如下:http://www.demodashi.com/demo/11995.html 1. 构建项目 使用Spring Boot快速构建一个Web工程,并导入与操作Excel相关的POI包以 ...
- C#用Infragistics 导入导出Excel
最近项目中有数据的导入导出Excel的需求,这里做简单整理. 公司用的是Infragistics的产品,付费,不需要本地安装Office. 有需要的朋友可以下载 Infragistics.2013.2 ...
- java POI 解析excel 2003和2007 直接转为List<Map> 返回
1.POI 官网下载jar包,3.5以上 2.项目导入jar包 3.参数:String数组--对应的excel列名对应的KEY,File excel文件,sheetNumber ---excel的s ...
- 用jxl解析excel内容
需要导入jxl.jar 下方表格为excel中内容: 序号 姓名 性别 生日 地址 1 测试1 男 1990-1-1 北京朝阳区 2 测试2 女 1998-2-2 北京海淀 3 测试3 男 1999- ...
随机推荐
- Python3中的新特性(2)——常见陷阱
1.文本与字节 Python3对文本字符串(字符)和二进制数据(字节)进行了严格区分,'hello'表示一个以Unicode编码保存的文本字符串,而b'hello'表示一个字节字符串. 在Python ...
- sonarQube Github pull request扫描代码
参考官方地址:https://docs.sonarqube.org/display/PLUG/GitHub+Plugin 运行环境:sonarQube6.2 + sonarScanner2.8 近来, ...
- UVA Rails(stl-stack)
具体思路是从B方向的序列 倒推 栈C 的入栈出栈顺序, 以B方向的5,4,3,2,1为例子:从一个数字5开始,要想从栈C拿到5号车厢,5号车厢得入栈C,且5号车厢处于栈顶位置,为了保证5号车 厢在 ...
- HDU 4528 小明系列故事――捉迷藏
广搜. 根据题意,可以知道状态总共有$4*n*m$种.每一个位置四种状态:两个都没有发现:发现$E$没发现$D$:发现$D$没发现$E$:两个都发现. 每次移动的花费都是$1$,队列里面状态的费用是单 ...
- 优先队列priority_queue
优先队列容器与队列一样,只能从队尾插入元素,从队首删除元素.但是它有一个特性,就是队列中最大的元素总是位于队首,所以出队时,并非按照先进先出的原则进行,而是将当前队列中最大的元素出队.这点类似于给队列 ...
- ASP.NET Core 2.2 基础知识(十一) ASP.NET Core 模块
ASP.NET Core 应用与进程内的 HTTP 服务器实现一起运行.该服务器实现侦听 HTTP 请求,并在一系列请求功能被写到 HttpContext 时,将这些请求展现到应用中. ASP.NET ...
- luogu P1772 [ZJOI2006]物流运输
题目描述 物流公司要把一批货物从码头A运到码头B.由于货物量比较大,需要n天才能运完.货物运输过程中一般要转停好几个码头.物流公司通常会设计一条固定的运输路线,以便对整个运输过程实施严格的管理和跟踪. ...
- 【分块】bzoj1901 Zju2112 Dynamic Rankings
区间k大,分块大法好,每个区间内存储一个有序表. 二分答案,统计在区间内小于二分到的答案的值的个数,在每个整块内二分.零散的暴力即可. 还是说∵有二分操作,∴每个块的大小定为sqrt(n*log2(n ...
- linux 处理两个文件的并集,交集,计数
1. 取出两个文件的并集(重复的行只保留一份) cat file1 file2 | sort | uniq 2. 取出两个文件的交集(只留下同时存在于两个文件中的文件) cat file1 file2 ...
- Swift中TableViewCell便利构造器写法
目前为止比较方便的一种方法,如果有更好的写法请通知我,谢谢!