手机
当前位置:查字典教程网 >编程开发 >相关技巧 >水晶报表 分页 的问题
水晶报表 分页 的问题
摘要:水晶报表分页汇总建三个公式字段,第一个(公式1)输入下面的公式:whileprintingrecords;globalnumbervarpt...

水晶报表分页汇总

建三个公式字段,第一个(公式1)输入下面的公式:

whileprintingrecords;

global numbervar ptotal;

ptotal:=0;

第二个(公式2)输入下面的公式:

whileprintingrecords;

global numbervar ptotal;

ptotal := ptotal + [要汇总的字段];

如果要汇总的字段不是数字,就用tonumber()函数转换;

第三个(公式3)输入下面的公式:

whileprintingrecords;

global numbervar ptotal;

把公式1放在页眉,公式2放在详细资料,并隐藏公式1和公式2;把公式3放在页脚,格式公式3,设置为你要显示的格式。这样就行了。

水晶报表分页并自动插入空白行

在论坛上经常会看到水晶报表分页的问题,这个很好解决。

但是自动插入空白行的问题却一直没有很好的答案,

经过研究找到一个变通的办法来实现了。

'分页

在详细资料上点格式化节,在后面页新建页打勾

公式中输入:

if onlastrecord then

FORMULA = FALSE

else

if RecordNumber mod 5 =0 then

FORMULA = TRUE

else

FORMULA = FALSE

end if

end if

'(BASIC 语法)

---------------------------------------------------------------------

最后页不足,用空行填充:

新增一个空白详细资料行,格式化此节,在抑制显示(无深化)打勾

公式中输入:

if not onlastrecord then

FORMULA = TRUE

else

if (RecordNumber mod 5 <= 1) then '第一个,1

FORMULA = TRUE

else

FORMULA = FALSE

end if

end if

'(BASIC 语法)

...接着第二个[ 新增一个空白详细资料行,格式化此节,在抑制显示(无深化)打勾 ]:

公式中输入:

if not onlastrecord then

FORMULA = TRUE

else

if (RecordNumber mod 5 <= 2) then '第二个,2

FORMULA = TRUE

else

FORMULA = FALSE

end if

end if

...接着第三个[ 新增一个空白详细资料行,格式化此节,在抑制显示(无深化)打勾 ]:

公式中输入:

if not onlastrecord then

FORMULA = TRUE

else

if (RecordNumber mod 5 <= 3) then '第三个,3

FORMULA = TRUE

else

FORMULA = FALSE

end if

end if

在论坛上经常会看到水晶报表分页的问题,这个很好解决。

但是自动插入空白行的问题却一直没有很好的答案,

经过研究找到一个变通的办法来实现了。

'分页

在详细资料上点格式化节,在后面页新建页打勾

公式中输入:

if onlastrecord then

FORMULA = FALSE

else

if RecordNumber mod 5 =0 then

FORMULA = TRUE

else

FORMULA = FALSE

end if

end if

'(BASIC 语法)

---------------------------------------------------------------------

最后页不足,用空行填充:

新增一个空白详细资料行,格式化此节,在抑制显示(无深化)打勾

公式中输入:

if not onlastrecord then

FORMULA = TRUE

else

if (RecordNumber mod 5 <= 1) then '第一个,1

FORMULA = TRUE

else

FORMULA = FALSE

end if

end if

'(BASIC 语法)

...接着第二个[ 新增一个空白详细资料行,格式化此节,在抑制显示(无深化)打勾 ]:

公式中输入:

if not onlastrecord then

FORMULA = TRUE

else

if (RecordNumber mod 5 <= 2) then '第二个,2

FORMULA = TRUE

else

FORMULA = FALSE

end if

end if

...接着第三个[ 新增一个空白详细资料行,格式化此节,在抑制显示(无深化)打勾 ]:

公式中输入:

if not onlastrecord then

FORMULA = TRUE

else

if (RecordNumber mod 5 <= 3) then '第三个,3

FORMULA = TRUE

else

FORMULA = FALSE

end if

end if

...(同理第四个,即最后5-1个)

(注:此方法适用于行数较少,上面是为5行为例,不过不觉得麻烦,对行数较多也可以用)...(同理第四个,即最后5-1个)

【水晶报表 分页 的问题】相关文章:

高性能WEB开发(5) 减少请求,响应的数据量

微信 小程序开发环境搭建详细介绍

windows 中 rn 区别于 类unix中的n 疑问说明

微信小程序下载工具及调试详解

算法系列15天速成 第七天 线性表【上】

UTF-8 编码中BOM的检测与删除

几款开源的中文分词系统

php和asp利用Shell.Application来执行程序的代码

POST与GET方法的区别简要分析

图片的色彩空间问题

精品推荐
分类导航