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页的需求, 使用本工具类时 ...
随机推荐
- c#对联合体的封装
https://blog.csdn.net/u012846041/article/details/37518313 标准C或者C++中均提供关键字定义联合结构,C#中未提供类似的关键字,但仍然可以定义 ...
- 有关素数判断的一些算法(总结&&对比)
素性测试是数论题中比较常用的一个技巧.它可以很基础,也可以很高级(哲学).这次主要要介绍一下有关素数判断的奇技淫巧 素数的判断主要分为两种:范围筛选型&&单个判断型 我们先从范围筛选型 ...
- Jlink使用技巧之合并烧写文件
前言 IAP(In-application-programming),即在应用中编程.当产品发布之后,可以通过网络方便的升级固件程序,而不需要拆机下载程序.IAP系统的固件一般由两部分组成,即Boot ...
- 记一次yarn导致cpu飙高的异常排查经历
yarn就先不介绍了,这次排坑经历还是有收获的,从日志到堆栈信息再到源码,很有意思,下面听我说 问题描述: 集群一台NodeManager的cpu负载飙高. 进程还在但是看日志已经不再向Resourc ...
- 浅谈java反射机制
目录 什么是反射 初探 初始化 类 构造函数 属性 方法 总结 思考 什么是反射 JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意 ...
- YouTube视频下载的12个软件(Win和Mac)
如今,观看视频已经成为人们生活中重要的一部分.很多时候,我们都需要用到视频,比如教育用途.会议报告.休闲娱乐以及广告宣传等.如果你觉得有时候资源不好找的话,不放去看下YouTube.YouTube是世 ...
- Python_复习_习题_29
# 之前做得的题 以后再遇到能保证会# 下周二考 :所有的知识# 面试题:认真对待## 三元运算符# 接收结果的变量 = 条件为真的结果 if 条件 else 条件为假的结果# 接收结果的变量 = “ ...
- LeetCode 363:Max Sum of Rectangle No Larger Than K
题目链接 链接:https://leetcode.com/problems/max-sum-of-rectangle-no-larger-than-k/description/ 题解&代码 1 ...
- SQLserver 进程被死锁问题解决
事务(进程ID xx)与另一个进程被死锁在 锁|通信缓冲区 资源上,并且已被选座死锁牺牲品.请重新运行该事务.Sqlserver 当出现这个错误时,如下图: 解决办法:更改数据库事务隔离级别 alte ...
- myBatis插件(plugins)
MyBatis 允许你在已映射语句执行过程中的某一点进行拦截调用.默认情况下,MyBatis 允许使用插件来拦截的方法调用包括: Executor (update, query, flushState ...