目的:访问url(http://localhost:8080/POIOutputExcel/outputexcel.do)实现excel导出,效果图如下:

文件目录(配置文件就不多说了,跟前面的随笔一样一样的)

  

User.java

public class User {
private Integer id;
private String name;
private Double cash;
//此处省略getter/setter方法
}

Datalist.java

public class Datalist {
//这里不走数据库,直接模拟数据库查询结果
public List<User> getUsers(int n){
List<User> list = new ArrayList<User>();
for (int i = 0; i < n; i++) {
User user = new User();
user.setId(i);
user.setName("xiaoming"+i);
user.setCash(1000.0+i);
list.add(user);
}
return list;
} }

BeanToMap.java

public class BeanToMap<T> {

    public Map<String,Object> getMap(T entity){
Field[] fields = entity.getClass().getDeclaredFields();
Map<String,Object> map = new HashMap<String,Object>();
for (int i = 0; i < fields.length; i++) {
String methodName = getMethodName(fields[i].getName());
try {
Method method = entity.getClass().getMethod(methodName);
map.put(fields[i].getName(),method.invoke(entity));
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
return map;
} public String getMethodName(String fieldName){
byte[] buffer = fieldName.getBytes();
buffer[0] = (byte)(buffer[0]-32);
String name = new String(buffer);
return "get"+name;
}
}

PoiExcelExport.java

public class PoiExcelExport<T> {
// excle导出名称
private String fileName;
// excel 表头
private String[] heads;
// excel 列
private String[] cols;
// 设置数值型的列 从0开始计数
private int[] numerics;
//list集合
private List<T> list;
// 输出流
private OutputStream out;
// 构造函数
public PoiExcelExport(String fileName, String[] heads, String[] cols, List<T> list, OutputStream out) {
this.fileName = fileName;
this.heads = heads;
this.cols = cols;
this.list = list;
this.out = out;
} // 构造函数 带数字类型
public PoiExcelExport(String fileName, String[] heads, String[] cols, List<T> list, int[] numerics, OutputStream out) {
this.fileName = fileName;
this.heads = heads;
this.cols = cols;
this.list = list;
this.numerics = numerics;
this.out = out;
} public void exportExcel() {
HSSFWorkbook hssfworkbook = new HSSFWorkbook(); // 创建一个excel对象
for (int i = 0; i <= (list.size() / 65535); i++) {
HSSFSheet hssfsheet = hssfworkbook.createSheet(); // 工作表
// 工作表名称
hssfworkbook.setSheetName(i, fileName.replace(".xls", "") + "(第" + (i + 1) + "页)");
int beginRows = 65535 * i;
int endRows = (list.size() > 65535 * (i + 1)) ? 65535 * (i + 1) - 1 : list.size() - 1;
HSSFRow hssfrowHead = hssfsheet.createRow(0);
// 输出excel 表头
if (heads != null && heads.length > 0) {
for (int h = 0; h < heads.length; h++) {
HSSFCell hssfcell = hssfrowHead.createCell(h,Cell.CELL_TYPE_STRING);
hssfcell.setCellValue(heads[h]);
}
}
// 要设置数值型 列表
HSSFCellStyle cellstyle = hssfworkbook.createCellStyle();
cellstyle.setDataFormat(HSSFDataFormat.getBuiltinFormat("##0"));
// 是否是数值型
boolean isnum = false;
// 输出excel 数据
for (int curRow = beginRows; curRow <= endRows; curRow++) {
// 获取数据
BeanToMap<T> btm = new BeanToMap<T>();
Map<String,Object> hm = btm.getMap(list.get(curRow));
// 创建excel行 表头1行 导致数据行数 延后一行
HSSFRow hssfrow = hssfsheet.createRow(curRow % 65535 + 1);
// 读取数据值
for (int k = 0; k < cols.length; k++) {
HSSFCell hssfcell = hssfrow.createCell(k);
// hssfcell.setCellValue(hm.get(cols[k])==null?"":hm.get(cols[k]).toString());
isnum = false;
for (int z = 0; z < numerics.length; z++) {
if (numerics[z] == k) {
isnum = true;
break;
}
} if (isnum) {
if (hm.get(cols[k]) == null || hm.get(cols[k]).equals("")) { } else {
hssfcell.setCellStyle(cellstyle);
hssfcell.setCellValue(Double.parseDouble(
hm.get(cols[k]) == null ? "" : hm.get(cols[k]).toString().replace(",", "")));
}
} else {
hssfcell.setCellValue(hm.get(cols[k]) == null ? "" : hm.get(cols[k]).toString());
}
}
} }
// excel生成完毕,写到输出流
try {
hssfworkbook.write(out);
out.flush();
out.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} }

ServletUtil.java

public class ServletUtil {
private String fileName;
private HttpServletRequest req;
private HttpServletResponse resp;
public OutputStream getOut(){
try {
return resp.getOutputStream();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
return null;
}
}
public ServletUtil(HttpServletResponse resp){
this.resp = resp;
}
public ServletUtil(String fileName,
HttpServletRequest req,
HttpServletResponse resp){
this.fileName = fileName;
this.req = req;
this.resp = resp;
}
public void poiExcelServlet(){
resp.setContentType("application/vnd.ms-excel");
String contentDisposition = "";
try {
if (req.getHeader("User-Agent").toLowerCase().indexOf("firefox") > 0) {
contentDisposition = "attachment; filename=\"" + new String(fileName.getBytes("UTF-8"), "ISO8859-1")
+ "\"";// firefox浏览器
} else {
contentDisposition = "attachment; filename=\"" + URLEncoder.encode(fileName, "UTF-8") + "\"";// IE浏览器
}
} catch (UnsupportedEncodingException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
resp.setHeader("Content-Disposition", contentDisposition);
resp.setCharacterEncoding("UTF-8");
}
}

UserController.java

@Controller
public class UserController { @RequestMapping(value = "/outputexcel.do")
public void showImgCode(HttpServletRequest req,
HttpServletResponse resp) {
String fileName = "springMVC导出excel小练习"; ServletUtil su = new ServletUtil(fileName, req, resp);
su.poiExcelServlet(); String[] heads = {"id号","姓名","身价(元)"};
String[] cols = {"id","name","cash"};
int[] numerics = {2};
List<User> list = new Datalist().getUsers(70000);//获取1000条样例数据 ServletUtil suresp = new ServletUtil(resp);
PoiExcelExport<User> pee = new PoiExcelExport<User>(fileName, heads, cols, list, numerics, suresp.getOut());
pee.exportExcel();
} }

springMVC框架+POI组件导出Excel的更多相关文章

  1. SpringMvc 使用poi导入导出Excel

    Util类 package com.common.util; public class ExportUtil { private XSSFWorkbook wb = null; private XSS ...

  2. 使用SpringMvc调用POI jar导出excel的源码

    @RequestMapping(value = "/result/export") public String export(ResultIn in,HttpServletRequ ...

  3. Apache POI组件操作Excel,制作报表(四)

    Apache POI组件操作Excel,制作报表(四) 博客分类: 探索实践 ExcelApacheSpringMVCServlet      上一篇我们介绍了如何制作复杂报表的分析和设计,本篇结合S ...

  4. Java利用POI导入导出Excel中的数据

         首先谈一下今天发生的一件开心的事,本着一颗android的心我被分配到了PB组,身在曹营心在汉啊!好吧,今天要记录和分享的是Java利用POI导入导出Excel中的数据.下面POI包的下载地 ...

  5. Apache POI组件操作Excel,制作报表(三)

    Apache POI组件操作Excel,制作报表(三) 博客分类: 探索实践 ExcelApache算法Office单元测试      上一篇介绍了POI组件操作Excel时如何对单元格和行进行设置, ...

  6. springMVC中使用POI方式导出excel至客户端、服务器实例

    Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. 这里的方法支持导出excel至项目所在服务器,或导 ...

  7. POI通用导出Excel数据(包括样式设计)

    前言 前一段时间我写过通用的导入Excel,前几天也写了导出pdf格式的,还有我之前搞得导出Word,我在之前的博客也都介绍了导出和导入是一个道理,无非是一个获取一个是赋值.昨天有一位同仁看了我的Ex ...

  8. Java POI导入导出Excel

    1.异常java.lang.NoClassDefFoundError: org/apache/poi/UnsupportedFileFormatException 解决方法: 使用的poi的相关jar ...

  9. java中使用poi导入导出excel文件_并自定义日期格式

    Apache POI项目的使命是创造和保持java API操纵各种文件格式基于Office Open XML标准(OOXML)和微软的OLE复合文档格式(OLE2)2.总之,你可以读写Excel文件使 ...

随机推荐

  1. C#图解教程 第十一章 枚举

    枚举 枚举 设置底层类型和显式值隐式成员编号 位标志 Flags特性使用位标志的示例 关于枚举的补充 枚举 枚举 枚举是由程序员定义的类型与类或结构一样. 与结构一样,枚举是值类型,因此直接存储它们的 ...

  2. Treeview 丢失焦点后依然高亮 SelectedNode

    参考:StackOverFlow.Control.Validating 事件 注意 TreeView 的 HideSelection 要保持为默认值True. private TreeNode pre ...

  3. 漫漫人生路,学点Jakarta基础-重写(覆盖)、重载

    首先我们现在开始进入Jakarta的时代,由原甲骨文易主到 Eclipse基金会下,但是不想舍弃java名字,因此基金会重新投票选出了Jakarta EE(雅加达).但是我们明白换汤汤不换药的道理,基 ...

  4. mybatis快速入门(二)

    这次接着上次写增删改查吧. 现将上节的方法改造一下,改造测试类. package cn.my.test; import java.io.IOException; import java.io.Inpu ...

  5. 洛谷P4219 [BJOI2014]大融合(LCT,Splay)

    LCT维护子树信息的思路总结与其它问题详见我的LCT总结 思路分析 动态连边,LCT题目跑不了了.然而这题又有点奇特的地方. 我们分析一下,查询操作就是要让我们求出砍断这条边后,x和y各自子树大小的乘 ...

  6. 【Luogu2444】病毒(AC自动机)

    [Luogu2444]病毒(AC自动机) 题面 洛谷 题解 如果存在一个无限长的串 证明可以在\(AC\)自动机上找到一个环 然后在上面可以无限跳 所以构建\(AC\)自动机 在上面跑\(dfs\)就 ...

  7. 什么是Docker??

    ​​Docker是一个轻量级虚拟机,也是一种Linux容器,它突破了以往的沙盒技术,解放了应用部署,让PaaS的应用场景更为广泛. ​ docker是通过内核虚拟化技术((namespaces及cgr ...

  8. ajax 状态码

    状态码定义 ... 10 信息1xx ... 10.1 100继续 ... 10.1.1 101交换协议 ... 10.1.2 成功的2xx ... 10.2 200 OK ... 10.2.1 20 ...

  9. jQuery中的自定义插件之----工厂方法(Factory Widget)

    jQuery赋予了我们很强大的插件自定义的功能,可以作为我们的武器库,应用到所有的网页中,使用的语法比较有意思,下面是对它的一些探讨. 遵循以下的原则: 1 IIFE 创建一个jQuery的scope ...

  10. c#抽取pdf文档标题(4)——机器学习以及决策树

    我的一位同事告诉我,pdf抽取标题,用机器学习可以完美解决问题,抽取的准确率比较高.于是,我看了一些资料,就动起手来,实践了下. 我主要是根据以往历史块的特征生成一个决策树,然后利用这棵决策树,去判断 ...