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

基于API导出带有页眉页脚的excel

阅读更多

Posted in 集智

 

集智数据平台报表中设置的页眉页脚在页面中是看不到的,如下图:


 


 


 

页面中的效果:



 


 

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




 


 

那么,如果将页眉页脚导入到导出的excel中呢.我们可以通过API来进行设置:


 

<%@ page import=”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.page import=”org.apache.poi2.hssf.usermodel.HSSFWorkbook”/>
<jsp:directive.page import=”org.apache.poi2.hssf.usermodel.HSSFSheet”/>
<jsp:directive.page import=”org.apache.poi2.hssf.usermodel.HSSFHeader”/>
<jsp:directive.page import=”org.apache.poi2.hssf.usermodel.HSSFFooter”/>


 

<%
 //设置所有report对象的值为GBK转码
 request.setCharacterEncoding(”GBK”);
 
 String reportFile = request.getParameter(”report”);
 if( reportFile==null ){
  reportFile = “report_4.raq”;
 }
 
 //第一步,读取报表模板
 InputStream fis=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()方法,所以我们先在服务器上生成这个文件
   String saveFile=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);
  
   //页眉页脚分3部分(左中右),
   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(int m=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());
 }
%>


 

 


 

更多了解各种复杂问题的处理,可以参考:报表导出打印展现导出打印各种复杂报表


 

分享到:
评论

相关推荐

    POI导出Word 页眉 页脚 标题设置

    下面是一个简单的示例,演示了如何创建一个带有页眉、页脚和标题的Word文档: ```java import org.apache.poi.hwpf.HWPFDocument; import org.apache.poi.hwpf.usermodel.*; public class PoiWordExample { ...

    POI3.5_HSSF_和XSSF_Excel操作快速入门手册

    在图形处理方面,POI提供了一个基于Graphics2D的API,允许用户在Excel文件中添加和编辑图形。通过这个API,用户可以将图像处理和图形绘制功能整合到Excel文件中,进一步丰富文档的内容和外观。 POI的使用可以让...

    利用freemarker 模板生成pdf ,利用easypoi 生成excel(带图片,水印,分页)

    本主题将探讨如何利用Freemarker模板生成PDF以及如何使用EasyPOI生成带有图片、水印和分页功能的Excel。 首先,让我们深入了解Freemarker。Freemarker是一个强大的模板引擎,它用于生成文本输出,如HTML、XML或PDF...

    jsp使用poi生成有格式的excel

    标题中的"jsp使用poi生成有格式的excel"指的是使用Java Server Pages (JSP) 技术,结合Apache POI库来创建带有特定格式(如样式、合并单元格、打印设置等)的Excel文件。Apache POI是Apache软件基金会的一个开源项目...

    Apache-Poi对word和excel的处理

    特别地,Apache-Poi对于Excel的模板处理能力也十分强大,它允许用户创建带有占位符的模板,并将数据填充进模板以生成个性化的工作簿。 在给出的部分内容中,我们可以看到一些字段标签如姓名、年龄、名字、分数等,...

    poi报表

    此示例创建了一个名为"My Sheet"的工作表,包含一个带有黄色背景的标题行和一个数据行。 通过掌握这些基本概念和API,你可以根据需求构建复杂的Excel报表,例如合并单元格、插入图表、应用公式等。在实际项目中,...

    操作word的jar包

    在这个"操作word的jar包"中,重点是Word的处理,特别是带有表格的文档。 1. **Apache POI的基本概念** - HWPF (Horrible Word Processor Format):Apache POI中的HWPF库,用于处理老版的Word 97-2003 (.doc) 文件...

    aspose-words-15.8.0-jdk16.jar

    4. **邮件合并**:通过合并数据源,如Excel表格或数据库,快速生成带有个性化信息的文档,如批量发送的信件或发票。 5. **布局和排版**:支持复杂的页面布局和排版设置,如页边距、页眉页脚、分节符、页码等。 6. ...

Global site tag (gtag.js) - Google Analytics