第十六章 BIRT报表疑难杂惑清理(续)
来源:互联网 发布:ac68u 网络唤醒 编辑:程序博客网 时间:2024/05/29 18:45
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页面,添加以上语句再转跳。
- 第十六章 BIRT报表疑难杂惑清理(续)
- 第十六章 BIRT报表疑难杂惑清理(续)
- 第十六章 BIRT报表疑难杂惑清理(续2)
- 第十六章 BIRT报表疑难杂惑清理(续2)
- 第十六章 BIRT疑难杂惑清理
- 第十六章 BIRT疑难杂惑清理
- 第十六章 BIRT疑难杂惑清理
- 第十六章 BIRT疑难杂惑清理
- 第六章 BIRT普通网格报表(续) .
- 第六章 BIRT普通网格报表(续2) .
- 第十二章 BIRT报表的部署与配置(续) .
- 第六章 BIRT普通网格报表(续) .
- 第六章 BIRT普通网格报表(续2) .
- 第十二章 BIRT报表的部署与配置(续) .
- (转)BIRT报表
- 第十三章 BIRT报表引擎API及报表API (续)-自定义web BIRT展示器
- 第十三章 BIRT报表引擎API及报表API (续)-自定义web BIRT展示器
- 第十三章 BIRT报表引擎API及报表API (续2)-利用BIRT设计引擎API生成报表
- 数据库中字段类型的含义
- 第十六章 BIRT疑难杂惑清理
- SQL语句 SQL Server中Text类型操作
- Python守护进程详解<转>
- Linux分区和挂载(mount命令的学习)
- 第十六章 BIRT报表疑难杂惑清理(续)
- svn不显示同步的标记
- SSH框架的执行原理
- GF[2^n]下的多项式乘法
- Sql server 修改数据库排序规则
- Java采用包结构
- 第十六章 BIRT报表疑难杂惑清理(续2)
- linux 系统上搭建SVN
- Oracle跨数据库查询并插入