第十六章 BIRT报表疑难杂惑清理(续)

16.2 关于BIRT分组报表打印或者导出EXCEL出现空白行的解决方案

上一节讲过怎么去除页眉页脚,组眉组脚的空行,不过这还不足以满足中国式复杂的报表。BIRT分组报表是一个非常好用的分组利器,无奈客户通常要求直接导出或者打印的EXCEL就格式良好,不允许有空行。俗话说懒人创造生活,背后的意思的勤快的人被生活创造。程序员通常就是被生活创造的那一种人。之前第十一章讲过可以在脚本中定义变量,可以导入java包,书写java或者javascript程序,这是BIRT提供给程序员非常厉害的一个开放接口,可以任由程序员发挥想象力改变报表运行时的显示。

我们还是以示例数据源为例讲解,新建报表testGroup.rptdesign,

新建数据集:

select PRODUCTCODE,productname,productline 
from  CLASSICMODELS.PRODUCTS 
创造一个数据列用来分组:

新建一个计算列Code,表达式生成器内容如下:

var v = row["PRODUCTCODE"];
v = v.toString();
var s = v.substring(0,3);
s;

这样我们的预览如下:

我们在设计编辑器中插入一个1行3列的表,分别把数据列拖入单元格的详细数据列

添加分组信息,分组依据就是Code

不过我们把列的页脚行,分组的页眉页脚行全都删除,这个时候设计器编辑器依然显示如下:

然后我们动用脚本的力量:

在大纲视图中选中报表名,在init方法中输入 var i=0;

我们在每行中自增i(i++),在每组中重置i(i=0);

 

最重要的一步,回到布局视图,选中Code单元格,在属性-可视性标签页下,输入可视性表达式

i>1

这个时候预览,就会如下图所示:

导出excel如下:

不会出现空行。

另外,关于集群环境session失效的另外一种解决方案是:

主要是由于浏览器的安全限制,Iframe跨域访问时,被访问的页面无法使用浏览器cookie,从而没办法保持session造成的。
在被访问的页面加上P3P头就可以解决。
代码如下:
response.addHeader("P3P","CP=CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR");

或者

response.addHeader("P3P","CP=CAO PSA OUR");

如果是直接从html中的javascript转跳至BIRT报表的,建议转跳至一个jsp页面,添加以上语句再转跳。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值