Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。
//创建Excel工作簿
HSSFWorkbook workbook = new HSSFWorkbook();
//创建Excel表名称
HSSFSheet sheet = workbook.createSheet("");
HSSFCell cell = null;
//设置单元格字体样式
HSSFCellStyle cellStyle = workbook.createCellStyle();
HSSFFont font = workbook.createFont();
//居中
cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
font.setFontHeightInPoints((short)12);
font.setFontName("黑体");
cellStyle.setFont(font);
上面是创建了EXCEL工作簿,定义了一些基本的单元格样式
//第一行主标题信息
HSSFRow row0 = sheet.createRow(0);
//设置行高
row0.setHeight((short) 500);
cell = row0.createCell(0);
cell.setCellValue(new HSSFRichTextString(""));
cell.setCellStyle(cellStyle);
int size = departs.size()+4;
//为每列设置单元格宽度
for(int i=0;i<size;i++){
sheet.setColumnWidth(i, 5000);
}
CellRangeAddress range = new CellRangeAddress(0, 0, 0,size);
sheet.addMergedRegion(range);
//第二行相关标题
HSSFRow row1 = sheet.createRow(1);
row1.setHeight((short) 400);
初始化第一行,定义行高等样式;创建单元格,给单元格赋值,根据算法定义默认的列宽;进行了单元格合并
单元格合并API,new CellRangeAddress(int 开始行,int 结束行,int 开始列,int 结束列);
下面就开始根据需要给每行和对应的每列单元格赋值,并将excel导出
//写excel导出信息
String fileName = ".xls";
rep.setHeader("Content-disposition",
"attachment; filename=" + new String(fileName.getBytes("GB2312"), "ISO8859-1"));
// 设定输出文件头
rep.setContentType("application/msexcel");// 定义输出类型
OutputStream outputStream = rep.getOutputStream();
workbook.write(outputStream);
outputStream.flush();
outputStream.close();