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页面,添加以上语句再转跳。