`
boilingblood
  • 浏览: 13264 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

用POI 生成Excel 并下载

阅读更多
public String exportExcel() {
/**
* 1: 生成标题 2:读取数据 3:设置数据 4:生成响应
*/
Company company = null;
List<Department> departments = null;
Department department = null;
BudgetSplit split = budgetSplitService.getSplitById(splitId);

// 表标题
if (split.getMainBodyType() == 1) { // 单位
company = organizationService.getCompanyById(split.getMainBody());
departments = organizationService.listDepartmentByCompany(split
.getMainBody());
} else if (split.getMainBodyType() == 2) { // 部门
department = organizationService.getDepartmentById(split
.getMainBody());
departments = organizationService.getChildrenDepartment(split
.getMainBody());
}

String fatherName = (company == null) ? ((department == null) ? ""
: department.getName()) : company.getName();

HSSFWorkbook workbook = new HSSFWorkbook();

String title = split.getCycleYear() + "_" + fatherName + "_预算分解";

HSSFSheet sheet = workbook.createSheet(title);
String header[] = { "年", "指标编码", "指标名称" };
HSSFRow row = sheet.createRow(0);

for (int i = 0; i < header.length; i++) {
CellRangeAddress region = new CellRangeAddress(0, 1, i, i);
sheet.addMergedRegion(region);
HSSFCell cell = row.createCell(i);
HSSFCellStyle style = workbook.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
HSSFFont font = workbook.createFont();
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
style.setFont(font);
cell.setCellStyle(style);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(header[i]);
}

// 生成分解表里的父部门 标题

CellRangeAddress region = new CellRangeAddress(0, 0, 3, 5);
sheet.addMergedRegion(region);
HSSFCell cell = row.createCell(3);
HSSFCellStyle style = workbook.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
HSSFFont font = workbook.createFont();
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
style.setFont(font);
cell.setCellStyle(style);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(fatherName);

// 生成子部门标题
for (int j = 0; j < departments.size(); j++) {
Department dep = departments.get(j);
region = new CellRangeAddress(0, 0, j * 3 + 6, j * 3 +;
sheet.addMergedRegion(region);
cell = row.createCell(j * 3 + 6);
style = workbook.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
font = workbook.createFont();
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
style.setFont(font);
cell.setCellStyle(style);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(dep.getName());
}

row = sheet.createRow(1);
cell = row.createCell(3);
style = workbook.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
font = workbook.createFont();
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
style.setFont(font);
cell.setCellStyle(style);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue("预算金额");

cell = row.createCell(4);
cell.setCellStyle(style);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue("分解合计");

cell = row.createCell(5);
cell.setCellStyle(style);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue("结余");

// 生成子部门
for (int k = 0; k < departments.size(); k++) {
region = new CellRangeAddress(0, 0, k * 3 + 6, k * 3 +;
sheet.addMergedRegion(region);
cell = row.createCell(k * 3 + 6);
cell.setCellStyle(style);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue("本部门上报金额");

region = new CellRangeAddress(0, 0, k * 3 + 6, k * 3 +;
sheet.addMergedRegion(region);
cell = row.createCell(k * 3 + 7);
cell.setCellStyle(style);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue("调整金额");

region = new CellRangeAddress(0, 0, k * 3 + 6, k * 3 +;
sheet.addMergedRegion(region);
cell = row.createCell(k * 3 +;
cell.setCellStyle(style);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue("预算金额");
}

// 设置值
List<Map<String, Object>> listMap = budgetSplitService
.loadBatchSplitIndexes(split);
for (int m = 0; m < listMap.size(); m++) {
Map dataRow = listMap.get(m);
row = sheet.createRow(m + 2);
cell = row.createCell(0);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(String.valueOf(dataRow.get("year")));

cell = row.createCell(1);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(String.valueOf(dataRow.get("indexCode")));

cell = row.createCell(2);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(String.valueOf(dataRow.get("indexName")));

// 设置总公司的值
cell = row.createCell(3);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue("0.0");

cell = row.createCell(4);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue("0.0");

cell = row.createCell(5);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue("0.0");

for (int n = 6; n < departments.size() * 3 + 6; n += 3) {
Department dept = departments.get((n - 6) / 3);
cell = row.createCell(n);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(getValue(dataRow, dept, "forwardValue_"));
cell = row.createCell(n + 1);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(getValue(dataRow, dept, "adjustValue_"));
cell = row.createCell(n + 2);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue(getValue(dataRow, dept, "splitValue_"));
}
}

try {
HttpServletResponse response = ServletActionContext.getResponse();
response.setContentType("application/msexcel;charset=UTF-8");
response.setHeader("content-disposition", "attachment;filename=\""
+ URLEncoder.encode(title, "UTF-8") + ".xls\"");
OutputStream os = response.getOutputStream();
workbook.write(os);
os.flush();
os.close();
} catch (Exception e) {
e.printStackTrace();
}
return null;
}

private String getValue(Map dataRow, Department dept, String str) {
String ret = String.valueOf(dataRow.get(str + dept.getId()));
return ret.equals("") ? "0.0" : ret;
}
分享到:
评论

相关推荐

    JAVA用POI生成Excel并下载

    在本主题中,我们将深入探讨如何使用POI库来生成Excel文件并进行下载,同时关注设置字体大小这一细节。 首先,我们需要在项目中引入Apache POI库。如果你使用Maven,可以在pom.xml文件中添加以下依赖: ```xml ...

    java的poi生成excel图表demo

    通过这个“java的poi生成excel图表demo”,我们可以学习如何利用POI创建动态的、数据驱动的Excel曲线图,进一步提升数据的可视性和理解性。这个压缩包中的“EexcelChart”可能是示例代码、测试数据或生成的Excel文件...

    使用poi生成Excel所需要的jar包

    在这个场景中,"使用poi生成Excel所需要的jar包"指的是利用Apache POI库来生成Excel文件。POI-3.9.jar是Apache POI项目的一个版本,包含了所有必要的类和方法,让我们可以处理Excel的XLS和XLSX格式。 首先,Apache ...

    POI生成Excel POI操作Excel POI读取Excel POI类库

    **POI生成Excel** 生成Excel文件主要涉及以下步骤: 1. **创建Workbook对象**:这是Excel文件的顶级容器,可以是XSSFWorkbook(.xlsx格式)或HSSFWorkbook(.xls格式)。 2. **创建Sheet对象**:Sheet代表Excel...

    poi生成excel表格

    Apache POI 是一个开源项目...以上是Apache POI生成Excel表格的基本知识点和操作步骤。通过这些示例,你可以理解如何在Java应用中利用POI进行Excel文件的创建、读取和修改,以及如何结合数据库操作实现数据的导入导出。

    android中poi生成word文档和excel文档

    在标题“android中poi生成word文档和excel文档”中提到的使用POI库生成Word和Excel文档,主要涉及到以下几个关键知识点: 1. **Apache POI 概述**:Apache POI 是一个开源项目,提供了一套API,用于读写Microsoft ...

    POI 生成EXCEL2007【含例子】

    标题 "POI 生成EXCEL2007【含例子】" 涉及到的知识点主要集中在Apache POI库的使用上,这是一个强大的Java API,用于读取、写入和修改Microsoft Office格式的文件,特别是Excel文件。在这个场景中,重点是创建和操作...

    Java POI 生成Excel(xlsx)文件

    下面将详细介绍如何使用Java POI库来生成Excel(xlsx)文件。 首先,我们需要引入Apache POI的依赖。如果你使用的是Maven,可以在pom.xml文件中添加以下依赖: ```xml &lt;groupId&gt;org.apache.poi &lt;artifactId&gt;poi-...

    POI生成excel报表

    ### POI生成Excel报表知识点详解 #### 一、Apache POI简介 Apache POI是Apache软件基金会的一个开源项目,主要用于处理Microsoft Office格式的文件。它提供了API来读写Word、Excel等Office文档格式。其中,处理...

    SpringMVC POI Excel 生成导出

    "SpringMVC POI Excel 生成导出" 这个标题指的是使用 SpringMVC 框架和 POI 库生成 Excel 文件,并将其导出。这个标题包含了三个关键词:SpringMVC、POI 和 Excel,它们是我们今天要探讨的主题。 描述解释 在这个...

    poi生成excel实例

    标题中的“poi生成excel实例”指的是使用Apache POI库来创建和操作Microsoft Excel文件的实践案例。Apache POI是开源的Java库,它允许开发者在Java应用中读写Microsoft Office格式的文件,包括Excel。 在描述中提到...

    使用POI生成EXCEL

    标题中的“使用POI生成EXCEL”指的是使用Apache POI库来创建Microsoft Excel文件的过程。Apache POI是一个开源项目,提供了Java API,可以用来读写Microsoft Office格式的文件,包括Excel(.xls和.xlsx格式)。这个...

    Java POI 生成Excel时显示货币格式

    在使用Java POI生成Excel时,为了使数据更易读和专业,我们经常需要设置单元格的格式,特别是当涉及到金额时,使用货币格式可以使数字更加直观。以下是一段示例代码,展示了如何在Excel单元格中设置货币格式: ```...

    利用POI生成Excel并通过Servlet下载示例

    本示例将详细解释如何利用POI生成Excel文件,并通过Servlet进行下载。 首先,了解Apache POI的基本用法。POI提供了HSSF(用于处理.xls格式,即Excel 97-2003格式)和XSSF(用于处理.xlsx格式,即Excel 2007及以上...

    利用POI解析excel并存入数据库demo

    `prepareStatement()` 方法则需要根据 Excel 文件的列结构生成相应的 INSERT 语句,并设置占位符。`getCellValue()` 方法则负责根据单元格类型(如字符串、数字、日期等)返回正确的值。 这个 demo 的核心是将 ...

    java调用poi生成excel文件

    java代码调用poi架包, 把数据生成excel文件, 导出到文件

    jsp利用POI生成Excel并在页面中导出的示例.docx

    本示例将详细介绍如何在JSP中利用POI库生成Excel文件,并直接在浏览器中导出。 首先,确保在项目中已经引入了Apache POI的依赖库。POI提供了对Excel 2003(HSSF)和Excel 2007以上版本(XSSF)的支持。在这个示例中...

    POI操作Excel完美生成水印

    以下是一个简化的示例代码片段,展示了如何使用Apache POI生成水印: ```java import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.*; //... 加载Excel文件 ... // 创建文字图片 ...

    图片缩略图以及poi生成excel文档

    平时工作中用到的一些技术点,拿出来和大家共享一下。 有些功能比较粗糙,如果大家有更加完善的示例或建议,欢迎交流。 1、jpg图片缩略图:ImageUtil ...2、poi创建excel:CDSHdlReport 3、计算表达式求值:Cal

    poi生成Excel及合并单元格示例

    在本示例中,我们将重点讨论如何使用 Apache POI 来生成 Excel 文件,并进行单元格的合并操作。 首先,我们需要引入 Apache POI 的相关依赖库。如果你使用的是 Maven,可以在项目的 `pom.xml` 文件中添加以下依赖:...

Global site tag (gtag.js) - Google Analytics