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