SSM poi通过模板 反射导出excel

1 import java.lang.reflect.Field;
2 import java.lang.reflect.Method;
3 import java.util.Iterator;
4 import java.util.List;
5
6 import org.apache.poi.hssf.usermodel.HSSFCell;
7 import org.apache.poi.hssf.usermodel.HSSFCellStyle;
8 import org.apache.poi.hssf.usermodel.HSSFRow;
9 import org.apache.poi.hssf.usermodel.HSSFSheet;
10 import org.apache.poi.hssf.usermodel.HSSFWorkbook;
11
12 /**
13 * Excel通用工具类
14 * @param sheetName 表格名字
15 * @param headers 表头
16 * @param columns 列(对象属性名)对应表头
17 * @param lists 数据源
18 */
19 public class ExcelUtil<T> {
20 public HSSFWorkbook export(String sheetName, String[] headers, String[] columns, List<T> lists) throws Exception {
21 HSSFWorkbook wb = new HSSFWorkbook();
22 HSSFSheet sheet = wb.createSheet(sheetName);
23 sheet.setDefaultColumnWidth(11);
24 HSSFCellStyle style = wb.createCellStyle();
25 HSSFRow row = sheet.createRow(0);
26 style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
27 style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
28 for (int i = 0; i < headers.length; i++) {
29 HSSFCell headerCell = row.createCell(i);
30 headerCell.setCellValue(headers[i]);
31 headerCell.setCellStyle(style);
32 }
33 Iterator<T> it = lists.iterator();
34 int rowIndex = 0;
35 while (it.hasNext()) {
36 rowIndex++;
37 row = sheet.createRow(rowIndex);
38 T t = it.next();
39 Field[] fields = t.getClass().getDeclaredFields();
40 for (int i = 0; i < fields.length; i++) {
41 Field field = fields[i];
42 String fieldName = field.getName();
43 for (int j = 0; j < columns.length; j++) {
44 if (fieldName.equals(columns[j])) {
45 String getMethodName ="get"+fieldName.substring(0,1).toUpperCase()+fieldName.substring(1);
46 Class<? extends Object> cls = t.getClass();
47 Method getMethod = cls.getMethod(getMethodName, new Class[] {});
48 Object val = getMethod.invoke(t, new Object[] {});
49 String textVal = null;
50 if (null != val) {
51 textVal = val.toString();
52 } else {
53 textVal = null;
54 }
55 HSSFCell hssfCell=row.createCell(j);
56 hssfCell.setCellValue(textVal);
57 hssfCell.setCellStyle(style);
58 }
59 }
60 }
61 }
62 return wb;
63 }
64 }


1 Server层
2
3 /**
4 * 导出数据
5 * @throws Exception
6 */
7 public HSSFWorkbook outputExcel() throws Exception {
8 List<Distribution> lists = mapper.selectByExample(new DistributionExample());
9 String sheetName = "债券分销表";
10 String[] headers = {"指令日期","组合代码","组合名字","业务类型","缴款金额","缴款日期",
11 "O32状态","是否加急","出款状态","主承状态","交收状态"}; //表头
12 String[] columns = {"instructionDate","compositeCode","combinationName","interestType",
13 "paymentAmount","paymentDate","o32Status","urgentStatus","cashFlowStatus",
14 "underwritingStatus","settlementState"}; //bean 属性名 需对应表头
15 ExcelUtil<Distribution> excelUtil = new ExcelUtil<Distribution>();
16 HSSFWorkbook wb=excelUtil.export(sheetName, headers, columns, lists);
17 //FileOutputStream fos= new FileOutputStream("E://dis.xls");
18 //wb.write(fos);
19 return wb;
20 }
21


1 @RequestMapping(produces="application/vnd.ms-excel;charset=UTF-8",value="qwangxiao.com /downloadExcel",method = RequestMethod.GET)
2 public void downloadExcel(HttpServletResponse response){
3 response.addHeader("Content-Disposition","attachment; filename=\"债券分销列表.xls\"" );
4 HSSFWorkbook wk=null;
5 OutputStream oStream=null;
6 try {
7 oStream = response.getOutputStream();
8 wk = distributionService.outputExcel();
9 wk.write(oStream);
10 }catch (Exception e) {
11 e.printStackTrace();
12 logger.info("导出Excel表格出现异常"+e);
13 }finally {
14 if(oStream!=null){
15 try {
16 oStream.close();
17 } catch (IOException e) {
18 e.printStackTrace();
19 }
20 }
21 }
22 }

SSM poi通过模板 反射导出excel的更多相关文章
- vue Excel导入,下载Excel模板,导出Excel
vue Excel导入,下载Excel模板,导出Excel vue Excel导入,下载Excel模板 <template> <div style="display: ...
- 使用POI插件,提取导出excel的工具类
在网站的不同的模块都需要使用到导入导出excel的功能,我们就需要写一个通用的工具类ExcelUtil. 我的思路:首先,导入和导出的Excel的文件格式固定:主标题,二级标题,数据行(姑且就这么叫) ...
- 反射导出 Excel
/// <summary> /// List 数据导出Excel /// </summary> /// <param name="list">数 ...
- 【poi】解决java导出excel 海量数据内存溢出问题
转自百度经验:http://jingyan.baidu.com/article/4853e1e5202c331909f72627.html 那里排版忒恶心,转来这里. 由于项目中有导出海量数据的需求, ...
- poi操作oracle数据库导出excel文件2
package com.test; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFound ...
- 尝试做一个.NET模板填充导出Excel工具
园友好,最近晚辈延续上篇后尝试进阶做成Excel模板填充数据生成工具 MiniExcel Template. 主要特点 同样以Stream流.延迟查询避免全部数据载入内存情况,做到1GB内存降低到只需 ...
- poi操作oracle数据库导出excel文件
HSSFWorkbook workBook = new HSSFWorkbook();// 创建 一个excel文档对象 HSSFSheet sheet = workBook.createSheet( ...
- 反射导出excel案例
1.代码案例: protected void btnExportExcel_Click(object sender, EventArgs e) { SetSearchValue(); Dictiona ...
- 根据模板导出Excel报表并生成多个Sheet页
因为最近用报表导出比较多,所有就提成了一个工具类,本工具类使用的场景为 根据提供的模板来导出Excel报表 并且可根据提供的模板Sheet页进行复制 从而实现多个Sheet页的需求, 使用本工具类时 ...
随机推荐
- Redis命令总结 (转)
Redis命令总结 连接操作相关的命令 quit:关闭连接(connection) auth:简单密码认证 持久化 save:将数据同步保存到磁盘 bgsave:将数据异步保存到磁盘 lastsa ...
- java 基础01
标识符:字母,下划线和美元符号,数字组成大小写敏感,无长度限制 关键字: 数据类型
- LDAP-openldap服务部署和测试(YUM安装)
1. 概述2. 服务端部署过程2.1 软件包说明2.2 部署过程2.3 配置过程3. 测试4. 生成LDIF格式文件4.1 安装migrationtools工具4.2 用migrationtools生 ...
- KVM虚拟机管理——资源调整
1. 概述2. 计算资源调整2.1 调整处理器配置2.2 调整内存配置3. 存储资源调整3.1 根分区扩展3.2 添加磁盘4. 网络资源调整 1. 概述 KVM在使用过程中,会涉及到计算(CPU,内存 ...
- Ionic 入门与实战之第二章第二节:Ionic 环境搭建之 Ionic Lab 使用
原文发表于我的技术博客 本文是「Ionic 入门与实战」系列连载的第二章第二节,主要对 Ionic Lab 工具作了介绍,并讲解了其使用方法,这也是一个开发 Ionic 比较好的调试工具. 原文发表于 ...
- 时间复杂度O(n^2)和O(nlog n)差距有多大?
0. 时间复杂度 接触到算法的小伙伴们都会知道时间复杂度(Time Complexity)的概念,这里先放出(渐进)时间复杂度的定义: 假设问题规模是\(n\),算法中基本操作重复执行的次数是\(n\ ...
- Linux下"负载均衡+高可用"集群的考虑点 以及 高可用方案说明(Keepalive/Heartbeat)
当下Linux运维技术越来越受到企业的关注和追捧, 在某些企业, 尤其是牵涉到电子商务和电子广告类的网站,通常会要求作负载均衡和高可用的Linux集群方案.那么如何实施Llinux集群架构,才能既有效 ...
- 关于git的一些体会:
周忠贤github链接:https://github.com/zhouzhongxian git学习心得:通过这次的学习,体会到了许多东西只要你用心去做,就没有什么做不成,,这次体会到了网上学习的重要 ...
- python 中的三元表达式及lambda
一.三元表达式 举一个简单的列子,很多地方都有这样的规定,比如用水或者用电,假设用水价格为3R/立方米,当你每个月用超过7立方米后,超出的水按照3.3R/立方米计价.然后写一个程序计算一个家庭每月的水 ...
- ExtJS Tab里放Grid高度自适应问题,官方Perfect方案。
出处:http://docs.sencha.com/extjs/4.2.1/extjs-build/examples/layout-browser/layouts/combination.js // ...