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

  1. vue Excel导入,下载Excel模板,导出Excel

    vue  Excel导入,下载Excel模板,导出Excel vue  Excel导入,下载Excel模板 <template> <div style="display: ...

  2. 使用POI插件,提取导出excel的工具类

    在网站的不同的模块都需要使用到导入导出excel的功能,我们就需要写一个通用的工具类ExcelUtil. 我的思路:首先,导入和导出的Excel的文件格式固定:主标题,二级标题,数据行(姑且就这么叫) ...

  3. 反射导出 Excel

    /// <summary> /// List 数据导出Excel /// </summary> /// <param name="list">数 ...

  4. 【poi】解决java导出excel 海量数据内存溢出问题

    转自百度经验:http://jingyan.baidu.com/article/4853e1e5202c331909f72627.html 那里排版忒恶心,转来这里. 由于项目中有导出海量数据的需求, ...

  5. poi操作oracle数据库导出excel文件2

    package com.test; import java.io.File;  import java.io.FileInputStream;  import java.io.FileNotFound ...

  6. 尝试做一个.NET模板填充导出Excel工具

    园友好,最近晚辈延续上篇后尝试进阶做成Excel模板填充数据生成工具 MiniExcel Template. 主要特点 同样以Stream流.延迟查询避免全部数据载入内存情况,做到1GB内存降低到只需 ...

  7. poi操作oracle数据库导出excel文件

    HSSFWorkbook workBook = new HSSFWorkbook();// 创建 一个excel文档对象 HSSFSheet sheet = workBook.createSheet( ...

  8. 反射导出excel案例

    1.代码案例: protected void btnExportExcel_Click(object sender, EventArgs e) { SetSearchValue(); Dictiona ...

  9. 根据模板导出Excel报表并生成多个Sheet页

    因为最近用报表导出比较多,所有就提成了一个工具类,本工具类使用的场景为  根据提供的模板来导出Excel报表 并且可根据提供的模板Sheet页进行复制 从而实现多个Sheet页的需求, 使用本工具类时 ...

随机推荐

  1. LOJ2803 CCC2018 平衡树 数论分块、记忆化搜索

    传送门 题意差评,其实就是一个递推式:\(f_1 = 1 , f_i = \sum\limits_{j=2}^i f_{\lfloor \frac{i}{j} \rfloor}\),然后求\(f_N\ ...

  2. java,javascript中的url编码

    真实场景 url示例如下 http://localhost:31956/Login/Auto?Token=e8a67a9f-c062-4964-b703-d79f29c8b64e&Return ...

  3. FlashWindowEx实现窗口在任务栏闪烁/变化颜色

    原文:FlashWindowEx实现窗口在任务栏闪烁/变化颜色 效果类似QQ收到新的会话消息任务栏颜色变化 附2小段代码: [System.Runtime.InteropServices.DllImp ...

  4. Spring Aop: 关于继承和execution target this @annotation

    1.多态 target指通过这个对象调用的方法   (匹配标识对象的所有方法)  getMethod() this指调用这个对象的方法 (匹配标识对象实现的方法) getDeclaredMethod( ...

  5. CentOS 7 安装Redis

    Linux安装Redis 一.下载并安装 $ wget http://download.redis.io/releases/redis-2.8.17.tar.gz $ tar xzf redis-2. ...

  6. python 小问题收集

    1,python安装sqlclient yum install python36u python36u-devel yum install gcc mariadb-devel pip3 install ...

  7. 个人作业-Week1(新增详细说明)

    快速看完整部教材,列出你仍然不懂的5到10个问题,发布在你的个人博客上. 如何提出有价值的问题? 请看这个文章:http://www.cnblogs.com/rocedu/p/5167941.html ...

  8. 第三周Linux学习报告

    Linux内核源代码简介: arch/x86中内容重点关注 init目录重要,内核启动相关的代码基本上都在init目录下.如main.c等.Start_kernel函数相当于普通C程序的main函数. ...

  9. OSGB数据压缩

    OSGB数据输出时压缩数据大小,采用如下设置 osgDB::writeNodeFile(*osgbNode, "xxx/xxxx.osgb", new osgDB::Options ...

  10. “数学口袋精灵”App的第三个Sprint计划----开发日记(第一天12.7~第十天12.16)

    “数学口袋精灵”第三个Sprint计划----第一天 项目进度: 基本完成一个小游戏,游戏具有:随机产生算式,判断对错功能.通过轻快的背景音乐,音效,给玩家提供一个良好的氛围.  任务分配: 冯美欣: ...