Struts2 poi导出excel

来源:互联网 发布:做淘宝店铺用什么软件 编辑:程序博客网 时间:2024/04/26 04:16


Action

private InputStream excelFile;

private String downloadFileName;

 

 

Setter&Getter

public String getDownloadFileName() {

SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd ");

 

String downloadFileName = (sf.format(new Date()).toString())

+ "项目信息.xls";

try {

downloadFileName = new String(downloadFileName.getBytes(),

"ISO8859-1");

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

return downloadFileName;

}

 

public void setDownloadFileName(String downloadFileName) {

this.downloadFileName = downloadFileName;

}

 

public InputStream getExcelFile() {

return excelFile;

}

 

public void setExcelFile(InputStream excelFile) {

this.excelFile = excelFile;

}

 

 

关键代码:

 

// 导出

public String export() throws Exception {

HttpServletResponse response = ServletActionContext.getResponse();

List<FrontProjectList> dataList = projectApplyBaseService

.query_ProjectApply3(pqc, 0, projectApplyBaseService

.count_queryTotalProject_consumption(pqc) + 1);

HSSFWorkbook workbook = exportExcel(dataList);

ByteArrayOutputStream output = new ByteArrayOutputStream();

workbook.write(output);

 

byte[] ba = output.toByteArray();

excelFile = new ByteArrayInputStream(ba);

output.flush();

output.close();

return "excel";

}

 

 

public HSSFWorkbook exportExcel(List dataList) throws Exception {

HSSFWorkbook workbook = null;

try {

// 这里的数据即时你要从后台取得的数据

 

// 创建工作簿实例

workbook = new HSSFWorkbook();

// 创建工作表实例

HSSFSheet sheet = workbook.createSheet("TscExcel");

// 设置列宽

this.setSheetColumnWidth(sheet);

// 获取样式

HSSFCellStyle style = this.createTitleStyle(workbook);

 

//   

if (dataList != null && dataList.size() > 0) {

// 创建第一行标题,标题名字的本地信息通过resources从资源文件中获取

HSSFRow row = sheet.createRow((short) 0);// 建立新行

 

this.createCell(row, 0, style, HSSFCell.CELL_TYPE_STRING, "序号");

this.createCell(row, 1, style, HSSFCell.CELL_TYPE_STRING,

"项目名称");

this.createCell(row, 2, style, HSSFCell.CELL_TYPE_STRING,

"项目类别");

this.createCell(row, 3, style, HSSFCell.CELL_TYPE_STRING,

"建设单位");

this.createCell(row, 4, style, HSSFCell.CELL_TYPE_STRING,

"牵头责任单位");

this.createCell(row, 5, style, HSSFCell.CELL_TYPE_STRING,

"建设起始年");

this.createCell(row, 6, style, HSSFCell.CELL_TYPE_STRING,

"总投资(万元)");

this.createCell(row, 7, style, HSSFCell.CELL_TYPE_STRING,

"申报时间");

// 给excel填充数据

for (int i = 0; i < dataList.size(); i++) {

// 将dataList里面的数据取出来,假设这里取出来的是Model,也就是某个javaBean的意思啦

FrontProjectList model = (FrontProjectList) dataList.get(i);

HSSFRow row1 = sheet.createRow((short) (i + 1));// 建立新行

this.createCell(row1, 0, style, HSSFCell.CELL_TYPE_STRING,

i + 1);

if (model.getXmmc() != null)

this.createCell(row1, 1, style,

HSSFCell.CELL_TYPE_STRING, model.getXmmc());

if (model.getXmlb() != null)

this.createCell(row1, 2, style,

HSSFCell.CELL_TYPE_STRING, model.getXmlb());

if (model.getXmdw() != null)

this.createCell(row1, 3, style,

HSSFCell.CELL_TYPE_STRING, model.getXmdw());

if (model.getZrbm() != null)

this.createCell(row1, 4, style,

HSSFCell.CELL_TYPE_STRING, model.getZrbm());

if (model.getJsqsn() != null)

this.createCell(row1, 5, style,

HSSFCell.CELL_TYPE_STRING, model.getJsqsn());

if (model.getZtz() != null)

this.createCell(row1, 6, style,

HSSFCell.CELL_TYPE_STRING, model.getZtz());

if (model.getSbsj() != null)

this.createCell(row1, 7, style,

HSSFCell.CELL_TYPE_STRING, model.getSbsj());

 

}

} else {

this.createCell(sheet.createRow(0), 0, style,

HSSFCell.CELL_TYPE_STRING, "查无资料");

}

} catch (Exception e) {

e.printStackTrace();

}

return workbook;

 

}

 

private void setSheetColumnWidth(HSSFSheet sheet) {

// 根据你数据里面的记录有多少列,就设置多少列

sheet.setColumnWidth(0, 3000);

sheet.setColumnWidth(1, 8000);

sheet.setColumnWidth(2, 3000);

sheet.setColumnWidth(3, 8000);

sheet.setColumnWidth(4, 8000);

sheet.setColumnWidth(5, 5000);

sheet.setColumnWidth(6, 5000);

sheet.setColumnWidth(7, 5000);

 

}

 

// 设置excel的title样式

private HSSFCellStyle createTitleStyle(HSSFWorkbook wb) {

HSSFFont boldFont = wb.createFont();

boldFont.setFontHeight((short) 200);

HSSFCellStyle style = wb.createCellStyle();

style.setFont(boldFont);

style.setDataFormat(HSSFDataFormat.getBuiltinFormat("###,##0.00"));

return style;

}

 

// 创建Excel单元格

private void createCell(HSSFRow row, int column, HSSFCellStyle style,

int cellType, Object value) {

HSSFCell cell = row.createCell(column);

if (style != null) {

cell.setCellStyle(style);

}

switch (cellType) {

case HSSFCell.CELL_TYPE_BLANK: {

}

break;

case HSSFCell.CELL_TYPE_STRING: {

cell.setCellValue(value.toString());

}

break;

case HSSFCell.CELL_TYPE_NUMERIC: {

cell.setCellType(HSSFCell.CELL_TYPE_NUMERIC);

cell.setCellValue(Double.parseDouble(value.toString()));

}

break;

default:

break;

}

}

0 0