使用反射将model数据下载到Excel中

package test.upload.utils;

import java.lang.reflect.Method;
import java.math.BigDecimal;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import java.util.Map; import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.CreationHelper;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.usermodel.Workbook; /**
 * 生成EXCEL的工具类
 * 
 * @author duandingyang
 * 
 */
public class ExcelUtils {     /**
     * 生成EXCEL的通用方法
     * 
     * @param filePath 生成EXCEL的地址
     * @param clazz 绑定数据的类型
     * @param list 数据列表
     * @param map EXCEL表头信息
     * @throws Exception
     */
    public static HSSFWorkbook generateExcel(Class<?> clazz, List<?> list,
            Map<String, ExcelTitle> map) throws Exception {         HSSFWorkbook wb = new HSSFWorkbook();
        CreationHelper helper = wb.getCreationHelper();
        HSSFSheet sheet = wb.createSheet("sheet1");
        HSSFRow row = sheet.createRow(0);
        CellStyle cellStyle = ExcelUtils.createStyleCell(wb);
        cellStyle.setFont(ExcelUtils.createFonts(wb));
        int i = 0;
        for (String attr : map.keySet()) {
            sheet.setColumnWidth(i, 5000);
            ExcelTitle excelTitle = map.get(attr);
            int order = excelTitle.getOrder();
            String title = excelTitle.getTitle();
            HSSFCell cell = row.createCell(order);
            cellStyle = ExcelUtils.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER,
                    CellStyle.VERTICAL_CENTER);
            cellStyle.setWrapText(true);    
            cell.setCellStyle(cellStyle);
            cell.setCellValue(title);
            i++;
        }
        int rowNum = 1;
        if (list != null) {
            for (Object obj : list) {
                row = sheet.createRow(rowNum);
                for (String attr : map.keySet()) {
                    ExcelTitle excelTitle = map.get(attr);
                    int order = excelTitle.getOrder();
                    Class<?> type = excelTitle.getType();
                    String getMethod = "get" + attr.substring(0, 1).toUpperCase()
                            + attr.substring(1);
                    Method method = clazz.getMethod(getMethod, new Class[] {});
                    Object value = method.invoke(obj, new Object[] {});
                    HSSFCell cell = row.createCell(order);
                    if (value != null) {
                        if (Double.class.equals(type)) {
                            cellStyle = ExcelUtils.setCellStyleAlignment(cellStyle,
                                    CellStyle.ALIGN_RIGHT, CellStyle.VERTICAL_CENTER);
                            cellStyle = ExcelUtils.setCellFormat(helper, cellStyle, "#,##0.00");
                            cell.setCellStyle(cellStyle);
                            double doubleValue = Double.valueOf(value.toString());
                            cell.setCellValue(doubleValue);
                        } else if (Long.class.equals(type)) {
                            cellStyle = ExcelUtils.setCellStyleAlignment(cellStyle,
                                    CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);
                            cell.setCellStyle(cellStyle);
                            long longValue = Long.valueOf(value.toString());
                            cell.setCellValue(longValue);
                        } else if (String.class.equals(type)) {
                            //                            cellStyle = ExcelUtils.setCellStyleAlignment(cellStyle,
                            //                                    CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);
                            //                            cell.setCellStyle(cellStyle);
                            cellStyle.setWrapText(true);   
                            cell.setCellStyle(cellStyle);
                            cell.setCellValue(new HSSFRichTextString(value.toString()));
                        } else if (Date.class.equals(type)) {
                            // TODO 处理时间
                            SimpleDateFormat format=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                            String ctime = format.format(value); 
                            cell.setCellValue(ctime);
                        }
                        else if (BigDecimal.class.equals(type)) {
                            BigDecimal bigDecimal=(BigDecimal) value;
                            String bigDecimalValue = bigDecimal.toString();
                            cell.setCellValue(bigDecimalValue);
                        }else if(Integer.class.equals(type)){
                            if(value != null){
                                 cell.setCellValue(Integer.parseInt((value.toString())));
                            }
                        }
                    }
                }
                rowNum++;
            }
        }
        return wb;
    }     public static CellStyle createStyleCell(Workbook wb) {
        CellStyle cellStyle = wb.createCellStyle();
        //        // 设置一个单元格边框颜色
        //        cellStyle.setBorderBottom(CellStyle.BORDER_THIN);
        //        cellStyle.setBorderTop(CellStyle.BORDER_THIN);
        //        cellStyle.setBorderLeft(CellStyle.BORDER_THIN);
        //        cellStyle.setBorderRight(CellStyle.BORDER_THIN);
        //        // 设置一个单元格边框颜色
        //        cellStyle.setRightBorderColor(IndexedColors.BLACK.getIndex());
        //        cellStyle.setLeftBorderColor(IndexedColors.BLACK.getIndex());
        //        cellStyle.setBottomBorderColor(IndexedColors.BLACK.getIndex());
        //        cellStyle.setTopBorderColor(IndexedColors.BLACK.getIndex());         return cellStyle;
    }     /**
     * 设置文字在单元格里面的位置 CellStyle.ALIGN_CENTER CellStyle.VERTICAL_CENTER
     * 
     * @param cellStyle
     * @param halign
     * @param valign
     * @return
     */
    public static CellStyle setCellStyleAlignment(CellStyle cellStyle, short halign, short valign) {
        // 设置上下
        cellStyle.setAlignment(halign);
        // 设置左右
        cellStyle.setVerticalAlignment(valign);
        return cellStyle;
    }     /**
     * 格式化单元格 如#,##0.00,m/d/yy去HSSFDataFormat或XSSFDataFormat里面找
     * 
     * @param cellStyle
     * @param fmt
     * @return
     */
    public static CellStyle setCellFormat(CreationHelper helper, CellStyle cellStyle, String fmt) {
        // 还可以用其它方法创建format
        cellStyle.setDataFormat(helper.createDataFormat().getFormat(fmt));
        return cellStyle;
    }     /**
     * 设置字体
     * 
     * @param wb
     * @return
     */
    public static Font createFonts(Workbook wb) {
        // 创建Font对象
        Font font = wb.createFont();
        // 设置字体
        font.setFontName("微软雅黑");
        // 着色
        font.setColor(HSSFColor.BLACK.index);
        return font;
    }     /**
     * 生成EXCEL通用方法使用的表头类
     * 
     * @author cuijianxing
     * 
     */
    public static class ExcelTitle {         private int order;         private Class<?> type;         private String title;         public int getOrder() {
            return order;
        }         public void setOrder(int order) {
            this.order = order;
        }         public String getTitle() {
            return title;
        }         public void setTitle(String title) {
            this.title = title;
        }         public Class<?> getType() {
            return type;
        }         public void setType(Class<?> type) {
            this.type = type;
        }         public ExcelTitle(int order, Class<?> type, String title) {
            super();
            this.order = order;
            this.type = type;
            this.title = title;
        }     }

}

controller层:

@RequestMapping(value = "/downloadUserData", method = RequestMethod.GET)
    public void downloadUserData(HttpServletRequest request,
            HttpServletResponse response) {
        response.setContentType("application/x-excel");
        response.setHeader("content-disposition", "attachment;filename="
                + "UserData.xls");
        response.setCharacterEncoding("UTF-8");
        List<User> users = userService.getUserList();
        Map<String, ExcelUtils.ExcelTitle> titleMap = this.getExcelTitleMap();
        OutputStream ouputStream = null;
        try {
            HSSFWorkbook workBook = ExcelUtils.generateExcel(User.class, users,
                    titleMap);
            ouputStream = response.getOutputStream();
            workBook.write(ouputStream);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                ouputStream.flush();
                ouputStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }     private Map<String, ExcelUtils.ExcelTitle> getExcelTitleMap() {
        Map<String, ExcelUtils.ExcelTitle> titleMap = new HashMap<String, ExcelUtils.ExcelTitle>();         ExcelUtils.ExcelTitle excelTitle0 = new ExcelUtils.ExcelTitle(0,
                String.class, "序号");
        titleMap.put("id", excelTitle0);         ExcelUtils.ExcelTitle excelTitle1 = new ExcelUtils.ExcelTitle(1,
                String.class, "姓名");
        titleMap.put("name", excelTitle1);         ExcelUtils.ExcelTitle excelTitle2 = new ExcelUtils.ExcelTitle(2,
                String.class, "电话");
        titleMap.put("phone", excelTitle2);         ExcelUtils.ExcelTitle excelTitle3 = new ExcelUtils.ExcelTitle(2,
                String.class, "地址");
        titleMap.put("address", excelTitle3);         return titleMap;

}

代码下载:

https://github.com/vincentduan/UploadExcel.git

下载数据到Excel,工具类的更多相关文章

  1. Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类

    Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类 ============================== ©Copyright 蕃薯耀 20 ...

  2. Python Excel工具类封装, 给excel表头搞点颜色

    封装Excel工具类 我们常用的excel工具类,读有xlrd,写有xlwt.有读有写,新一代库有pandas,openpyxl等等. 大家用法都差不多,今天博主就介绍新手最爱,我也爱的xlrd和xl ...

  3. excel工具类

    excel工具类 import com.iport.framework.util.ValidateUtil; import org.apache.commons.lang3.StringUtils; ...

  4. 导入导出Excel工具类ExcelUtil

    前言 前段时间做的分布式集成平台项目中,许多模块都用到了导入导出Excel的功能,于是决定封装一个ExcelUtil类,专门用来处理Excel的导入和导出 本项目的持久化层用的是JPA(底层用hibe ...

  5. 自己封装的poi操作Excel工具类

    自己封装的poi操作Excel工具类 在上一篇文章<使用poi读写Excel>中分享了一下poi操作Excel的简单示例,这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完 ...

  6. java 解析excel工具类

      java 解析excel工具类 CreateTime--2018年3月5日16:48:08 Author:Marydon ReadExcelUtils.java import java.io.Fi ...

  7. Java解析Excel工具类(兼容xls和xlsx)

    依赖jar <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml&l ...

  8. java里poi操作Excel工具类【我改】

    参考原文: https://www.cnblogs.com/yizhang/p/7244917.html 我改: package test; import java.io.File; import j ...

  9. java操作excel 工具类

    java操作excel 可参考https://blog.csdn.net/xunwei0303/article/details/53213130 直接上代码: 一.java生成excel文件: pac ...

  10. javaEE开发之导出excel工具类

    web开发中,一个系统的普通需求也包含导出excel,一般採用POI做统计报表导出excel. 导出excel工具类: import java.io.FileOutputStream; import ...

随机推荐

  1. git 本地与远程仓库出现代码冲突解决方法

    提交过程中报错: [python@heaven-00 Selesystem]$ git push -u origin masterUsername for 'https://github.com': ...

  2. upload 上传 加token 在 :headers='headers' 注意 不要直接写$refs.upload.headers = {} 这样vue会警告 修改组件内部变量

    upload 上传 加token 在 :headers='headers' 注意 不要直接写$refs.upload.headers = {} 这样vue会警告 修改组件内部变量 <Upload ...

  3. 【整理】解决vue不相关组件之间的数据传递----vuex的学习笔记,解决报错this.$store.commit is not a function

    解决vue不相关组件之间的数据传递----vuex的学习笔记,解决报错this.$store.commit is not a function https://www.cnblogs.com/jaso ...

  4. OSI七层模型和TCP/IP五层模型详解

    OSI是一个开放性的通信系统互连参考模型,他是一个定义得非常好的协议规范.OSI模型有7层结构,每层都可以有几个子层. OSI的7层从上到下分别是 7 应用层 6 表示层 5 会话层 4 传输层 3 ...

  5. #PHP#微信支付 第二篇 JSAPI 调用统一下单接口获取预支付交易数据

    上一篇讲到成功获取 openid,本篇要调用微信统一接口创建预支付交易单,并获取到相关数据,以便(后边)在微信内调起H5支付 第三步,调用微信统一下单接口创建预支付交易单 微信统一下单API是微信支付 ...

  6. C-基础:函数返回局部变量

    一般的来说,函数是可以返回局部变量的. 局部变量的作用域只在函数内部,在函数返回后,局部变量的内存已经释放了.因此,如果函数返回的是局部变量的值,不涉及地址,程序不会出错.但是如果返回的是局部变量的地 ...

  7. “打开ftp服务器上的文件夹时发生错误,请检查是否有权限访问该文件夹"

    阿里云虚拟主机上传网站程序 问题场景:网页制作完成后,程序需上传至虚拟主机 注意事项: 1.Windows系统的主机请将全部网页文件直接上传到FTP根目录,即 / . 2. 如果网页文件较多,上传较慢 ...

  8. Linux内核——进程管理之SMP负载均衡(基于版本4.x)

    <奔跑吧linux内核>3.3笔记,不足之处还望大家批评指正 根据实际物理属性,CPU域分类如图1所示. 图1 CPU域分类 问题一:一个4核处理器中的每个物理CPU拥有独立L1 cach ...

  9. Python旅途——文件操作

    Python--文件操作 1.理解文件操作 可能有的时候有人会在想为什么要对文件进行操作,无论对于文件还是网络之间的交互,我们都是建立在数据之上的,如果我们没有数据,那么很多的事情也就不能够成立,比如 ...

  10. 大数据学习——securecrt同时向多个tab窗口发送相同的命令

    右键选中 然后在下面空白窗口写命令就可以了