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;
直接提示给用户是否保存或打开此文档
打开保存后的文件: