导入解析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(

url:’xx.do’,

dataType:’json’,

onSubmit:function(){return true;},//return false则会阻止表单提交

success:function(data){

//成功后的回调函数

}

);

Controller:

处理请求的方法参数用(MultipartFile uploadFile)类型接收

解析excel内容步骤:

  1. 通过传过来的uploadFile拿到流:

a)         ImputStream is = uploadFile.getInputStraam();

  1. 创建poiSysteam:

    fs = new POIFSFileSystem(is);

  1. 创建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的标题

  1. 得到一行里的某个单元格:

a)         HSSFCell cell = row.getCell(0);

b)         通过HSSFCell  单元格类型拿到单元格的数据

  1. 获取单元格的type: type = cell.getCellType();
  2. HSSFCell.CELL_TYPE_FORMUL数字类型:cell.getNumericCellValue();
  3. HSSFCell.CELL_TYPE_STRING:类型cell.getRichStringCellValue();
  4. HSSFCell.CELL_TYPE_FORMULA:类型

If(HSSFDateUtil.isCellDateFormatted(cell)){

Date date = cell.getDateCellValue();

}

  1. 身份证号避免科学计数法:

    DecimalFormat df = new DecimalFormat("0");

    cellvalue = df.format(cell.getNumericCellValue());

  1.     如果cell==null 的话,就给一个’’空字符串给他

7. 每一行的数据,可以自己定义一个类来保存,类中的字段于行里面的每一列对应

也可以用一个Map<Integer,String>-à <行号,行里面的内容>

二.   下载项目中的资源

  1. 方式一:

<a href='/res/excel/广东省补贴金额表.xls'>下载excel文档模板:</a>

  1. 方式二:

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小结的更多相关文章

  1. EasyPOI导入导出Excel

    EasyPOI工具可以方便的写出Excel导出,Excel模板导出,Excel导入,Word模板导出,通过简单的注解和模板 导入maven依赖 <dependency> <group ...

  2. oracle xmltype导入并解析Excel数据--前言

    通常,很多的时候,我们需要导入Excel数据到系统中,但是Excel数据需要我们去各种校验,比如身份证校验,手机号码校验等等. 校验失败的数据,提供Excel导出错误原因,提示给用户. 如此,如果校验 ...

  3. nodejs:导出Excel和解析导入的Excel

    用的是koa2框架,但好好处理一下,用express框架也是可以的.导出的Excel是xlsx的格式,解析导入Excel的有xlsx和csv格式.通常导入Excel是要上传的,然后获取文件的路径,这里 ...

  4. POI完美解析Excel数据到对象集合中(可用于将EXCEL数据导入到数据库)

    实现思路: 1.获取WorkBook对象,在这里使用WorkbookFactory.create(is); // 这种方式解析Excel.2003/2007/2010都没问题: 2.对行数据进行解析 ...

  5. C#用Infragistics 导入导出Excel(一)

    最近项目中有数据的导入导出Excel的需求,这里做简单整理. 公司用的是Infragistics的产品,付费,不需要本地安装Office. 有需要的朋友可以下载 Infragistics.2013.2 ...

  6. Java基于注解和反射导入导出Excel

    代码地址如下:http://www.demodashi.com/demo/11995.html 1. 构建项目 使用Spring Boot快速构建一个Web工程,并导入与操作Excel相关的POI包以 ...

  7. C#用Infragistics 导入导出Excel

    最近项目中有数据的导入导出Excel的需求,这里做简单整理. 公司用的是Infragistics的产品,付费,不需要本地安装Office. 有需要的朋友可以下载 Infragistics.2013.2 ...

  8. java POI 解析excel 2003和2007 直接转为List<Map> 返回

    1.POI 官网下载jar包,3.5以上 2.项目导入jar包 3.参数:String数组--对应的excel列名对应的KEY,File  excel文件,sheetNumber ---excel的s ...

  9. 用jxl解析excel内容

    需要导入jxl.jar 下方表格为excel中内容: 序号 姓名 性别 生日 地址 1 测试1 男 1990-1-1 北京朝阳区 2 测试2 女 1998-2-2 北京海淀 3 测试3 男 1999- ...

随机推荐

  1. php 单文件上传

    php 单文件上传 通过 PHP,可以把文件上传到服务器. 创建一个文件上传表单 允许用户从表单上传文件是非常有用的. 请看下面这个供上传文件的 HTML 表单: Filename: 请留意如下有关此 ...

  2. MySql 分页关键字(limit)

    mysql分页关键字: limit m,n --m:表示从哪一行开始查,n:查询多少条 oracle分页关键字:: rownum SqlServer:top(2005以下版本)  row_number ...

  3. 关闭浏览器session就被干掉的假象的问题

    当在前台取出session时,关闭浏览器后再次访问服务器,这时服务器返回了一个null,此时的返回的session并非之前的那个session而是一个新的session. -->先来看看sess ...

  4. 初识sql注入及sqlmap

    对于sql注入小白的我,上午在红黑联盟的网站上恶补了一下sql注入的基础知识,(走马观花)似乎明白sql注入是怎么一回事,也看了一些关于sqlmap的资料,再次记录一下吧 下面是关于sqlmap这个工 ...

  5. linux中Firefox浏览器 手动安装 flash

    打开firefox浏览器,当你打开有关音频或者视频的网站时候,会提示你安装 flash,可是,官网提示,需要手动安装. 1.先从提示的官网上下载好文件 “install_flash_player_11 ...

  6. UVa247

    题目连接(vj,比较方便):https://vjudge.net/problem/UVA-247 Description:If you’ve seen television commercials f ...

  7. POJ 2079 Triangle (凸包+旋转卡壳)

    [题目链接] http://poj.org/problem?id=2079 [题目大意] 给出一些点,求出能组成的最大面积的三角形 [题解] 最大三角形一定位于凸包上,因此我们先求凸包,再在凸包上计算 ...

  8. 【块状树】【树链剖分】bzoj1036 [ZJOI2008]树的统计Count

    很早之前用树链剖分写过,但是代码太长太难写,省选现场就写错了. #include<cstdio> #include<algorithm> #include<cstring ...

  9. (转)MOMO的Unity3D研究院之深入理解Unity脚本的执行顺序(六十二)

    http://www.xuanyusong.com/archives/2378 Unity是不支持多线程的,也就是说我们必须要在主线程中操作它,可是Unity可以同时创建很多脚本,并且可以分别绑定在不 ...

  10. Scala实战高手****第17课:Scala并发编程实战及Spark源码阅读

    package com.wanji.scala.test import javax.swing.text.AbstractDocument.Content import scala.actors.Ac ...