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

时间:2021-12-15 11:39:47

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;

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

这样我们的预览如下:

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

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

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

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

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

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

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

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

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

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

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

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

 

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

i>1

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

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

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

导出excel如下:

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

不会出现空行。

另外,关于集群环境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页面,添加以上语句再转跳。