POI导出excel,对于所有的VO实体都通用.

 /* 前面是列定义,后面是VO属性
     * para :主管海关,自定义类型,内部清单号-customMasterLabel,entryTypeLabel,internalListNo
     * list : 数据list<VO>
     * */
    public static String commonExport(String para,List list) throws IllegalAccessException, InvocationTargetException, NoSuchMethodException{
        HttpServletResponse response = ServletActionContext.getResponse();

        /*
         * POI 操作Excel - 步骤:
         * */
        HSSFWorkbook workbook = new HSSFWorkbook();
        ServletOutputStream out = null;
        try {
            out = response.getOutputStream();
        } catch (IOException e1) {
            // TODO Auto-generated catch block
            e1.printStackTrace();
        }
        HSSFSheet sheet = workbook.createSheet("sheet1");
        sheet.setColumnWidth(0, 1500); //设置序号列宽,其他列暂时一样宽
        sheet.setDefaultColumnWidth ((short)12);                        // 设置工作表列宽
        sheet.setDefaultRowHeight((short)250);                           // 设置工作表行高
        /*
         * sheet样式定义【getColumnTopStyle()/getStyle()均为自定义方法 - 在下面  - 可扩展】
         * */
        //HSSFCellStyle columnTopStyle = ExportExcelUtilsStyle.getColumnTopStyle(workbook);//获取列头样式对象
        //HSSFCellStyle style = ExportExcelUtilsStyle.getStyle(workbook);                  //单元格样式对象
        //列头数组定义
        para = "序号,"+para;
        String[] s = para.split("-");
        String s0 = s[0];
        String s1 = s[1];
        List titleList = Arrays.asList(s0.split(","));
        List colList = Arrays.asList(s1.split(","));
        //String[] label = ExportExcelUtilsModel.getExportMoedel(modelFlag);
        // 定义所需列数
        int columnNum = titleList.size();
        //设置列头
        HSSFRow row1 = sheet.createRow((short)0);               // 在索引0的位置创建行(最顶端的行)
        HSSFCell cell1 = null;                                  // 在索引0的位置创建单元格(左上端)
        // 将列头设置到sheet的单元格中
        for(int n=0;n<columnNum;n++){
            cell1 = row1.createCell((short)(n));                //创建列头对应个数的单元格
            cell1.setCellType(HSSFCell.CELL_TYPE_STRING);       //设置列头单元格的数据类型
            cell1.setCellValue(titleList.get(n).toString());     //设置列头单元格的值
            //cell1.setCellStyle(columnTopStyle);                 //设置列头单元格样式
        }

        if(null==list||list.size()==0){
            return "exportList size is zero";
        }
        int i=1;
        for(int m=0;m<list.size();m++){
            StringBuffer sb = new StringBuffer();
            String result="";
            for(int k=0;k<colList.size();k++){
                result = BeanUtils.getProperty(list.get(m),colList.get(k).toString());
                if(k==0){
                    sb.append(result);
                }else{
                    sb.append(","+result);
                }

            }
            //将属性转化成字符串数组的格式以便于写到sheet中
            String contentStr = i+","+sb.toString();
            List c = Arrays.asList(contentStr.split(","));

            //创建行(从下面的i+1要注意,第0行是列头,因此创建新行要从下一行开始)
            HSSFRow row = sheet.createRow(i);                             //创建所需的行数
            for(short j=0;j<columnNum;j++){
                HSSFCell cell = row.createCell(j,HSSFCell.CELL_TYPE_STRING);//设置单元格的数据类型
                cell.setCellValue(c.get(j).toString());                                    //设置单元格的值
                //cell.setCellStyle(style);                                   //设置单元格样式
            }
            i++;
        }
        if(workbook !=null){
            // 获取当前时间用作文件名
            try {
                String filename = "导出文件的名字" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date());
                response.setContentType("application/ms-excel");
                response.setHeader("Content-Disposition", "filename="+new String(filename.toString().concat(".xls").getBytes(),"UTF-8"));
                workbook.write(out);
                out.flush();        // 缓冲
                out.close();        // 关闭流(养成好的习惯打开了就别忘记关闭)
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }

        return "导出成功";
    }

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-08-30 18:20:58

POI导出excel,对于所有的VO实体都通用.的相关文章

使用poi导出Excel

很多时候,一个软件应用程序需要生成Microsoft Excel文件格式的报告.有时,一个应用程序甚至希望将Excel文件作为输入数据. 常见的java Excel  API Java Aspose Cells Java Aspose Cells 是一种纯粹的Java授权的Excel API,开发和供应商Aspose发布.这个API的最新版本是8.1.2,发布于2014年7月,是一个丰富而厚重的API(普通Java类和AWT类的组合)设计,可以读.写和操纵电子表格Excel的组件.此API常见用

java中使用poi导出excel表格数据并且可以手动修改导出路径

在我们开发项目中,很多时候会提出这样的需求:将前端的某某数据以excel表格导出,今天就给大家写一个简单的模板. 这里我们选择使用poi导出excel: 第一步:导入需要的jar包到 lib 文件夹下 jar包下载路径:http://download.csdn.net/download/pumpkin09/7077011 第二步:添加poi导出工具类 1 package com.yjd.admin.util; 2 3 import java.io.IOException; 4 import ja

使用Apache POI导出Excel小结--导出XLS格式文档

使用Apache POI导出Excel小结 关于使用Apache POI导出Excel我大概会分三篇文章去写 使用Apache POI导出Excel小结--导出XLS格式文档 使用Apache POI导出Excel小结--导出XLSX格式文档 使用Apache POI导出Excel--大数量导出 导出XLS格式文档 做企业应用项目难免会有数据导出到Excel的需求,最近在使用其,并对导出Excel封装成工具类开放出来供大家参考.关于Apache POI Excel基本的概念与操作我在这里就不啰嗦

POI导出EXCEL经典实现

在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作.而数据导出的格式一般是EXCEL或者PDF,我这里就用两篇文章分别给大家介绍下.(注意,我们这里说的数据导出可不是数据库中的数据导出!么误会啦^_^) 呵呵,首先我们来导出EXCEL格式的文件吧.现在主流的操作Excel文件的开源工具有很多,用得比较多的就是Apache的POI及JExcelAPI.这里我们用Apache POI!我们先去Apach

POI导出EXCEL经典实现(转)

http://www.cnblogs.com/xwdreamer/archive/2011/07/20/2296975.html 1.Apache POI简介 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程式对Microsoft Office格式档案读和写的功能. .NET的开发人员则可以利用NPOI (POI for .NET) 来存取 POI 的功能. 2.POI结构 HSSF - 提供读写Microsoft Excel XLS格式档案的功能.XS

JAVA关于POI导出Excel内存溢出的解决方案

JAVA关于POI导出Excel内存溢出的解决方案 在我们使用JAVA开发过程中,经常要导出查询获得的数据,这些数据一般情况下都是以Excel存储的,因此我们在导出数据的时候要使用JAVA的POI库,其主要是对各种windows平台的数据格式进行操作,在这里,我们是对Excel操作. 生成Excel的过程原理是这样的,首先,我们对数据库进行查询,获取相应的结果集,一般是list集合,然后生成Workbook对象,根据生成的Workbook对象获取sheet对象,根据此sheet对象获取Row对象

用POI导出excel时,较长的数字不想被自动变为科学计数法的解决方式(转)

做过很多次导出excel了.都碰到一个问题,内容里如果包含一个比较长的数字,比如订单号“2546541656596”,excel会自动变成科学计数法... 弄过好几次都没有解决,最近又要导出excel了,下决心一定要找到解决办法 自己在excel里测试过,较长的数字,都会自动变成科学计数法,除非我们把单元格格式设置成“文本型” 哈哈,似乎找到了思路:用poi先把单元格设置成“文本型”就可以了把. 从文档里找到了这个方法HSSFCell.setCellType(int type),怎么看这个方法都

poi导出excel

Java使用poi组件导出excel报表,能导出excel报表的还可以使用jxl组件,但jxl想对于poi功能有限,jxl应该不能载excel插入浮动层图片,poi能很好的实现输出excel各种功能,介绍poi导出excel功能实现案例,算比较常用的功能实现以及导出excel需要注意的地方,采用的是poi-3.8-20120326.jar,poi-ooxml-3.8-20120326.jar,poi-scratchpad-3.8-20120326.jar 输出表格 poi输出excel最基本是输

Java POI 导出EXCEL经典实现 Java导出Excel弹出下载框

在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作.而数据导出的格式一般是EXCEL或者PDF,我这里就用两篇文章分别给大家介绍下.(注意,我们这里说的数据导出可不是数据库中的数据导出!么误会啦^_^) 呵呵,首先我们来导出EXCEL格式的文件吧.现在主流的操作Excel文件的开源工具有很多,用得比较多的就是Apache的POI及JExcelAPI.这里我们用Apache POI!我们先去Apach