如何利用API导出带有页眉页脚的excel
在报表中设置的页眉页脚在页面中是看不到的,如下图:
页面中的效果:
在打印的时候,可以看到页眉页脚的效果:
那么,如果将页眉页脚导入到导出的excel中呢.我们可以通过API来进行设置:
<%@ pageimport="com.runqian.report4.model.*"%>
<%@ page import="com.runqian.report4.usermodel.*"%>
<%@ page import="com.runqian.report4.view.excel.*" %>
<%@ page import="com.runqian.report4.util.*" %>
<jsp:directive.pageimport="org.apache.poi2.hssf.usermodel.HSSFWorkbook"/>
<jsp:directive.pageimport="org.apache.poi2.hssf.usermodel.HSSFSheet"/>
<jsp:directive.page import="org.apache.poi2.hssf.usermodel.HSSFHeader"/>
<jsp:directive.pageimport="org.apache.poi2.hssf.usermodel.HSSFFooter"/>
<%
//设置所有report对象的值为GBK转码
request.setCharacterEncoding("GBK");
String reportFile = request.getParameter("report");
if( reportFile==null ){
reportFile = "report_4.raq";
}
//第一步,读取报表模板
InputStreamfis=application.getResourceAsStream("/reportFiles/"+reportFile);
ReportDefine rd = (ReportDefine)ReportUtils.read( fis );
//第二步,设置报表授权文件,运算报表
Context context = new Context();
//计算前,设置参数与宏
ParamMetaData pmd = rd.getParamMetaData();
String paramOrMocrName = "";
if(pmd != null){
for(int i = 0;i <pmd.getParamCount(); i ++){
paramOrMocrName = pmd.getParam(i).getParamName();
context.setParamValue(paramOrMocrName,request.getParameter(paramOrMocrName));
}
}
MacroMetaData mmd = rd.getMacroMetaData();
if( mmd != null ){
for(int i = 0; i < mmd.getMacroCount(); i ++){
paramOrMocrName = mmd.getMacro(i).getMacroName();
context.setMacroValue(paramOrMocrName,request.getParameter(paramOrMocrName));
}
}
Engine enging = new Engine( rd, context);
IReport iReport = enging.calc();
//生成Excel文件,因为jsp里不能直接用response的out.print()方法,所以我们先在服务器上生成这个文件
StringsaveFile=request.getRealPath("/reportFiles/")+"/"+reportFile+".xls";
ExcelReport eReoprt = new ExcelReport();
eReoprt.export(iReport);
FileOutputStream fos = new FileOutputStream( saveFile );
eReoprt.saveTo(fos);
fos.close();
HSSFWorkbook wb = new HSSFWorkbook(new FileInputStream(saveFile));
wb.setSheetName(0,"表1");
HSSFSheet s=wb.getSheetAt(0);
HSSFHeader hss = s.getHeader();
//hss.setCenter("aaaa");
StringBuffer stringBuffer = new StringBuffer();
StringBuffer sb = new StringBuffer();
int rowNum = iReport.getRowCount();
int colNum = iReport.getColCount();
sb.append("行数:"+rowNum+";列数:"+colNum);
//部分(左中右),
int centerStartCol =colNum/3+1; //中间部分开始列
int rightStartCol = colNum/3*2+colNum%3+1; //右边部分开始列
sb.append(";中间开始部分:"+centerStartCol+";右边开始部分:"+rightStartCol);
//页眉左边部分
for(int i=1,j=rowNum;i<=j;i++){
IRowCell iRowCell=iReport.getRowCell(i);
if( iRowCell.getRowType()==iRowCell.TYPE_PAGE_HEADER ){
if(iRowCell.getRowVisible()!=false ){
for(int m=1,n=centerStartCol;m<=n;m++){
INormalCell cell =iReport.getCell(i,(short)m);
sb.append(";左边部分:"+cell.isMerged());
Object obj=cell.getValue();
if(obj!=null){
stringBuffer.append(obj.toString());
HSSFHeader hh=s.getHeader();
hh.setLeft(stringBuffer.toString());
}
}
stringBuffer.append("\r");
}
}
}
stringBuffer.delete(0,stringBuffer.length());
//页眉中间部分
System.out.println(sb.toString());
for(int i=1,j=rowNum;i<=j;i++){
IRowCell iRowCell=iReport.getRowCell(i);
if( iRowCell.getRowType()==iRowCell.TYPE_PAGE_HEADER ){
if(iRowCell.getRowVisible()!=false ){
for(intm=rightStartCol,n=rightStartCol;m<=n;m++){
INormalCell cell = iReport.getCell(i,(short)m);
sb.append(";中间部分:"+cell.isMerged());
Object obj=cell.getValue();
if(obj!=null){
stringBuffer.append(obj.toString());
HSSFHeader hh=s.getHeader();
hh.setCenter(stringBuffer.toString());
}
}
stringBuffer.append("\r");
}
}
}
stringBuffer.delete(0,stringBuffer.length());
System.out.println(sb.toString());
//页眉右边部分
for(int i=1,j=rowNum;i<=j;i++){
IRowCell iRowCell=iReport.getRowCell(i);
if( iRowCell.getRowType()==iRowCell.TYPE_PAGE_HEADER ){
if(iRowCell.getRowVisible()!=false ){
for(int m=centerStartCol,n=colNum;m<=n;m++){
INormalCell cell =iReport.getCell(i,(short)m);
sb.append(";右边部分:"+cell.isMerged());
Object obj=cell.getValue();
if(obj!=null){
stringBuffer.append(obj.toString());
HSSFHeader hh=s.getHeader();
hh.setCenter(stringBuffer.toString());
}
}
stringBuffer.append("\r");
}
}
}
for(int i=1,j=iReport.getColCount();i<=j;i++){
IColCell irc=iReport.getColCell((short)i);
if(irc.getBreakPage()){
s.setColumnBreak((short)(i-1));
}
}
//结束分页
//页眉开始
HSSFHeader hh=s.getHeader();
System.out.println("日期&D:"+HSSFHeader.date());
System.out.println("当前页&P:"+HSSFHeader.page());
System.out.println("页数&N:"+HSSFHeader.numPages());
System.out.println("时间&T:"+HSSFHeader.time());
System.out.println("日期&D:"+HSSFHeader.date());
//页眉结束
//设置页脚
HSSFFooter footer = s.getFooter();
footer.setCenter( "第 " + HSSFFooter.page() +"
共 " + HSSFFooter.numPages());
//页脚结束
//标题行
System.out.println("========="+stringBuffer);
System.out.println("第一行第五列:"+iReport.getCell(1,(short)5).getValue().toString());
//转跳到我们刚才生成的文件
wb.write(new FileOutputStream(saveFile));
System.out.println("Excel文件生成结束,文件保存在:"+saveFile);
response.sendRedirect(request.getContextPath()+"/reportFiles/"+reportFile+".xls");
for(int i=1;i<=iReport.getColCount();i++){
System.out.println(iReport.getCell(1,(short)i).getValue());
}
%>
如何利用API导出带有页眉页脚的excel的更多相关文章
- iText + Freemarker实现pdf的导出,支持中文、css以及图片,页眉页脚,页眉添加图片
本文为了记录自己的实现过程,具体的实现步骤是参考博文 https://www.cnblogs.com/youzhibing/p/7692366.html 来实现的,只是在他的基础上添加了页眉页脚及页眉 ...
- itext 生成pdf文件添加页眉页脚
原文来自:https://www.cnblogs.com/joann/p/5511905.html 我只是记录所有jar版本,由于版本冲突及不兼容很让人头疼的,一共需要5个jar, 其中itextpd ...
- LaTeX 页眉页脚的设置
Latex中页眉页脚的设置 1. 首先要加页眉页脚的话,需要启动宏: 我通常用fancyhdr宏包来设置页眉和页脚. \usepackage{fancyhdr} 我们在 LaTeX 中先把 page ...
- 【Itext】7步制作Itext5页眉页脚pdf实现第几页共几页
itext5页眉页脚工具类,实现page x of y 完美兼容各种格式大小文档A4/B5/B3,兼容各种文档格式自动计算页脚XY轴坐标 鉴于没人做的这么细致,自己就写了一个itext5页眉页脚工具类 ...
- 在C#中实现Word页眉页脚的全部功能
页眉页脚经常使用于文章排版,在Word工具栏里.我们能够加入页眉,页脚,页码,日期和时间.图片等信息和内容.页眉/页脚有两个额外选项:首页不同,奇偶页不同.有时在不同的节(section)里插入不同的 ...
- 关于JavaScript打印去掉页眉页脚
因为这个问题,Google和百度都查了个遍,网上主要解决方案都是这一个代码: <script language="JavaScript"> var hkey_root, ...
- 使用C#在word中插入页眉页脚
//插入页脚 public void InsertFooter(string footer) { if (ActiveWindow.ActivePane.View.Type == WdViewType ...
- 【itext】7步制作兼容各种文档格式的Itext5页眉页脚 实现page x pf y
itext5页眉页脚工具类,实现page x of y 完美兼容各种格式大小文档A4/B5/B3,兼容各种文档格式自动计算页脚XY轴坐标 鉴于没人做的这么细致,自己就写了一个itext5页眉页脚工具类 ...
- C#word(2007)操作类--新建文档、添加页眉页脚、设置格式、添加文本和超链接、添加图片、表格处理、文档格式转化
转:http://www.cnblogs.com/lantionzy/archive/2009/10/23/1588511.html 1.新建Word文档 #region 新建Word文档/// &l ...
随机推荐
- java --Method
MethodDemo class MethodDemo { public static void main(String[] args) { //调用自定义的方法. draw(4,5); draw(8 ...
- 4、xamarin forms 设置安卓的toolbar的高度
降低学习成本是每个.NET传教士义务与责任. 建立生态,保护生态,见者有份. 今天有群友说 如何调整 toolbar 的 高度. 最初遇到这个问题第一反映就是CustomRender 设置高度借助la ...
- ElasticSearch-SQL 安装和使用
ES上线之后,用lucene语法来查询数据,学习成本略高,所以考虑用es-sql来简化这部分的操作. ES版本:5.4.0,节点部署如下: master node:3 client node:2,po ...
- java泛型---通配符,泛型嵌套
package generic; import java.util.ArrayList; import java.util.List; /** * ? -->通配符,类型不确定,用于声明 变量| ...
- FoxitReader软件下载并安装(图文详解)
不多说,直接上干货! FoxitReader官方网址:https://www.foxitsoftware.com/downloads/ 结束 欢迎大家,加入我的微信公众号:大数据躺过的坑 ...
- PMP备考指南之第一章:引论
本文已同步至 GitHub/Gitee/公众号,感兴趣的同学帮忙点波关注~ 第一章 引论 1."项目管理知识体系":应该包含所有行业.应用领域项目管理的具体知识.技能.方法和实践 ...
- 分布式ID生成方法-趋势有序的全局唯一ID
一.需求缘起 几乎所有的业务系统,都有生成一个记录标识的需求,例如: (1)消息标识:message-id (2)订单标识:order-id (3)帖子标识:tiezi-id 这个记录标识往往就是数据 ...
- redis实战笔记(10)-第10章 扩展Redis
本章主要内容 扩展读性能 扩展写性能以及内存容量 扩展复杂的查询 随着Redis的使用越来越多, 只使用一台Redis服务器没办法存储所有数据或者没办法处理所有读写请求的问题迟早都会出现, 这 ...
- POJ 1251 Jungle Roads(Kruskal算法求解MST)
题目: The Head Elder of the tropical island of Lagrishan has a problem. A burst of foreign aid money w ...
- hadoop学习笔记(三):hadoop文件结构
hadoop完整安装目录结构: 比较重要的包有以下4个: src hadoop源码包.最核心的代码所在目录为core.hdfs和mapred,他们分别实现了hadoop最重要的3个模块:基础公共库.H ...