在报表中设置的页眉页脚在页面中是看不到的,如下图:

页面中的效果:

在打印的时候,可以看到页眉页脚的效果:

那么,如果将页眉页脚导入到导出的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的更多相关文章

  1. iText + Freemarker实现pdf的导出,支持中文、css以及图片,页眉页脚,页眉添加图片

    本文为了记录自己的实现过程,具体的实现步骤是参考博文 https://www.cnblogs.com/youzhibing/p/7692366.html 来实现的,只是在他的基础上添加了页眉页脚及页眉 ...

  2. itext 生成pdf文件添加页眉页脚

    原文来自:https://www.cnblogs.com/joann/p/5511905.html 我只是记录所有jar版本,由于版本冲突及不兼容很让人头疼的,一共需要5个jar, 其中itextpd ...

  3. LaTeX 页眉页脚的设置

    Latex中页眉页脚的设置 1. 首先要加页眉页脚的话,需要启动宏: 我通常用fancyhdr宏包来设置页眉和页脚. \usepackage{fancyhdr} 我们在 LaTeX 中先把 page ...

  4. 【Itext】7步制作Itext5页眉页脚pdf实现第几页共几页

    itext5页眉页脚工具类,实现page x of y 完美兼容各种格式大小文档A4/B5/B3,兼容各种文档格式自动计算页脚XY轴坐标 鉴于没人做的这么细致,自己就写了一个itext5页眉页脚工具类 ...

  5. 在C#中实现Word页眉页脚的全部功能

    页眉页脚经常使用于文章排版,在Word工具栏里.我们能够加入页眉,页脚,页码,日期和时间.图片等信息和内容.页眉/页脚有两个额外选项:首页不同,奇偶页不同.有时在不同的节(section)里插入不同的 ...

  6. 关于JavaScript打印去掉页眉页脚

    因为这个问题,Google和百度都查了个遍,网上主要解决方案都是这一个代码: <script language="JavaScript"> var hkey_root, ...

  7. 使用C#在word中插入页眉页脚

    //插入页脚 public void InsertFooter(string footer) { if (ActiveWindow.ActivePane.View.Type == WdViewType ...

  8. 【itext】7步制作兼容各种文档格式的Itext5页眉页脚 实现page x pf y

    itext5页眉页脚工具类,实现page x of y 完美兼容各种格式大小文档A4/B5/B3,兼容各种文档格式自动计算页脚XY轴坐标 鉴于没人做的这么细致,自己就写了一个itext5页眉页脚工具类 ...

  9. C#word(2007)操作类--新建文档、添加页眉页脚、设置格式、添加文本和超链接、添加图片、表格处理、文档格式转化

    转:http://www.cnblogs.com/lantionzy/archive/2009/10/23/1588511.html 1.新建Word文档 #region 新建Word文档/// &l ...

随机推荐

  1. Jmeter中文乱码

    方法一 添加后置管理器BeanShell PostProcessor 填入prev.setDataEncoding("UTF-8") 方法二 在请求的 Content encodi ...

  2. Hive导出表数据

    法一: hive (stuchoosecourse) > insert overwrite local directory '/home/landen/文档/exportDir'         ...

  3. EJB3 阶段总结+一个EJB3案例 (2)

    这篇博文接着上一篇博文的EJB案例. 在上一篇博文中,将程序的架构基本给描述出来了,EJB模块分为5层. 1)DB层,即数据库层 在则一部分,我使用的数据库为mysql.在EJB程序中,访问数据库是通 ...

  4. 漫谈NIO(1)之计算机IO实现

    1.前言 此系列将尽可能详细介绍断更博客半年以来个人的一个成长,主要是对Netty的源码的一个解读记录,将从整个计算机宏观IO体系上,到Java的原生NIO例子最后到Netty的源码解读.不求完全掌握 ...

  5. EF 数据库连接约定(Connection String Conventions in Code First)

    一个典型的EF应用大多数情况下是一个DbContext的派生类(derived class)来控制,通常可以使用该派生类调用DbContext的构造函数,来控制以下的东西: (1).上下文如何连接到数 ...

  6. 第6章—渲染web视图—使用Thymeleaf

    使用Thymeleaf 长期以来,jsp在视图领域有非常重要的地位,随着时间的变迁,出现了一位新的挑战者:Thymeleaf,Thymeleaf是原生的,不依赖于标签库.它能够在接受原始HTML的地方 ...

  7. Git版本控制原理和常用指令说明

    平时在Android Studio开发Android项目,习惯了点击右键或图标直接拉新fetch,pull,commit和push.但是必要的时候还得在终端输入命令行.比如正在开发新版本v3.0,老板 ...

  8. 分区助手官网使用教程(专业版、绿色版和WinPE版)(图文详解)

    不多说,直接上干货! 详情见 http://www.disktool.cn/jiaocheng/index.html http://www.disktool.cn/jiaocheng/index2.h ...

  9. 虚拟网络编辑器的知识和出现的一些问题(没有VMnet0或VMnet8)

    不多说,直接上干货! 安装好的虚拟机,没有VMnet0!!! 解决的办法: 就可以了. 那么,问题现在又来了? 但是,每次都要这样,以右键,管理员身份运行,再关闭之后,以普通双击方式,即又没有VMne ...

  10. Google Guava--Guava新增集合

    Multiset Multiset 虽然带了个set但是却允许重复元素,与set相同的是不保证元素顺序. 使用场景:获取文章中单词的出现次数 String[] wordArr = new String ...