ExtJS4+SSH 实现Excel导出

来源:互联网 发布:mac启动引导里没os 编辑:程序博客网 时间:2024/05/21 09:29

1.说明

在项目中,我们经常需要导出数据到Excel中。

  前台使用Extjs4.2

  后台使用SSH。

  导出Excel使用Apache的POI组件


POI下载地址:http://poi.apache.org/download.html

POI的Excel导出学习网站:http://poi.apache.org/spreadsheet/quick-guide.html

参考博文:http://blog.csdn.net/gavinloo/article/details/6707828


2. 后台使用 SSH技术 + POI组件 实现excel导出功能

(1)导出功能实现类源码如下:

import java.io.OutputStream;import java.text.SimpleDateFormat;import java.util.Date;import java.util.List;import javax.servlet.http.HttpServletResponse;import org.apache.poi.hssf.usermodel.HSSFCell;import org.apache.poi.hssf.usermodel.HSSFCellStyle;import org.apache.poi.hssf.usermodel.HSSFFont;import org.apache.poi.hssf.usermodel.HSSFHeader;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;/** * 利用开源组件POI导出EXCEL文档 * @param <T> 应用泛型,代表任意一个符合javabean风格的类 */public class ExportExcelUtil<T> {//excel中sheet的名称private String sheetName ="报表内容";        public ExportExcelUtil() {super();}public ExportExcelUtil(String sheetName) {super();this.sheetName = sheetName;}    /**     * 这是一个通用的方法,利用了JAVA的反射机制,可以将放置在JAVA集合中并且符号一定条件的数据以EXCEL 的形式输出到指定IO设备上     * @param headers     *            表格属性列名数组     * @param dataSet     *            需要显示的数据集合,集合中一定要放置符合javabean风格的类的对象。     * @param response     *            与输出设备关联的流对象,可以将EXCEL文档导出到本地文件或者网络中     */    @SuppressWarnings("unchecked")    public void setExcelContents(String[] headers,List<VmReport> dataSet,HttpServletResponse response) {    //创建一个新的Excel          HSSFWorkbook workBook = new HSSFWorkbook();          //创建sheet页          HSSFSheet sheet = workBook.createSheet(sheetName);        // 设置表格默认列宽度为25个字节        sheet.setDefaultColumnWidth((short) 25);        //创建header页          HSSFHeader header = sheet.getHeader();          //设置标题居中          header.setCenter("标题");                  // 生成一个样式        HSSFCellStyle style = workBook.createCellStyle();        // 设置这些样式        style.setFillForegroundColor(HSSFColor.SKY_BLUE.index);        style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);        style.setBorderBottom(HSSFCellStyle.BORDER_THIN);        style.setBorderLeft(HSSFCellStyle.BORDER_THIN);        style.setBorderRight(HSSFCellStyle.BORDER_THIN);        style.setBorderTop(HSSFCellStyle.BORDER_THIN);        style.setAlignment(HSSFCellStyle.ALIGN_CENTER);        // 生成一个字体        HSSFFont font = workBook.createFont();        font.setColor(HSSFColor.VIOLET.index);        font.setFontHeightInPoints((short) 12);        font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);        // 把字体应用到当前的样式        style.setFont(font);                // 生成并设置另一个样式        HSSFCellStyle style2 = workBook.createCellStyle();        style2.setFillForegroundColor(HSSFColor.LIGHT_YELLOW.index);        style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);        style2.setBorderBottom(HSSFCellStyle.BORDER_THIN);        style2.setBorderLeft(HSSFCellStyle.BORDER_THIN);        style2.setBorderRight(HSSFCellStyle.BORDER_THIN);        style2.setBorderTop(HSSFCellStyle.BORDER_THIN);        style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);        style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);        // 生成另一个字体        HSSFFont font2 = workBook.createFont();        font2.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);        // 把字体应用到当前的样式        style2.setFont(font2);                //设置第一行为Header          HSSFRow row = sheet.createRow(0);          //设置第一行的内容和风格        for(int i=0;i<headers.length;i++){         HSSFCell cell = row.createCell(i);             cell.setCellStyle(style);             cell.setCellValue(headers[i]);        }        //设置数据        if(dataSet != null && !dataSet.isEmpty()) {              for(int i = 0; i < dataSet.size(); i++) {              VmReport vmport = dataSet.get(i);              //生成一行                row = sheet.createRow(i + 1);                  //设置内容和风格                for(int j=0;j<headers.length;j++){                   HSSFCell cell = row.createCell(j);                    cell.setCellStyle(style2);                    switch(j){                    case 0:                    cell.setCellValue(vmport.getName());                    break;                    case 1:                    cell.setCellValue(vmport.getIp());                    break;                    case 2:                    cell.setCellValue(vmport.getCpuHighest());                    break;                    case 3:                    cell.setCellValue(vmport.getCpuLowest());                    break;                    case 4:                    cell.setCellValue(vmport.getMemHighest());                    break;                    case 5:                    cell.setCellValue(vmport.getMemLowest());                    break;                    }               }            }          }          //通过Response把数据以Excel格式保存          response.reset();          response.setContentType("application/msexcel;charset=UTF-8");        //时间格式        SimpleDateFormat dateformat=new SimpleDateFormat("yyyyMMddHHmmss");String time=dateformat.format(new Date());        try {              response.addHeader("Content-Disposition", "attachment;filename=\""                      + new String((sheetName+"_" + time+".xls").getBytes("GBK"),                              "ISO8859_1") + "\"");              OutputStream out = response.getOutputStream();              workBook.write(out);             out.flush();              out.close();          } catch (Exception e) {              e.printStackTrace();          }    }    public String getSheetName() {return sheetName;}public void setSheetName(String sheetName) {this.sheetName = sheetName;}}

(2)Struts的Action中调用处

public String exportVmInfo() {//解析前台传递过来的参数//......//获取数据库中的数据,此处的dataSet是从数据库中获取的数据。保密起见,未写出。List<VmReport> dataSet = null;String title="报表Sheet的名称....";String[] headers = { "名称", "IP地址", "CPU利用率最高", "CPU利用率最低", "内存利用率最高","内存利用率最低"};//获取response对象HttpServletResponse response = ServletActionContext.getResponse();//导出数据至excel中ExportExcelUtil<VmReport> exportExcelUtil = new ExportExcelUtil<VmReport>();exportExcelUtil.setSheetName(title);exportExcelUtil.setExcelContents(headers, dataSet,response);//返回null才正确return null;}

(3)Struts的XML配置文件

<action name="exportVmInfo" class="vmReportAction" method="exportVmInfo"> <result type="stream"> </result></action>

3.前台Extjs调用,实现Excel的导出

window.location.href = 'vmReport/exportVmInfo.do? '+       'startTime='+ startTime +       '&endTime='+ endTime +       '&metricType='+ metricType;  

直接提示给用户是否保存或打开此文档


打开保存后的文件:


0 0
原创粉丝点击