Crystal Reports基本语法

简介:
在Crystal Reports中支持两种语法,Crystal和Basic,本文只介绍Crystal语法。
Crystal 语法是不区分大小写的。
1)  数据类型
在Crystal Reports中,支持七种简单数据类型
数字:1,-100
货币:$100.1,-$12或CCur(100.1),CCur(-12)
字符串:“123”,“字符串”
布尔值:True,False
日期:CDate(“2/2/2009”)
时间:CTime(“10:20 am”)
日期时间:#10:20 am#,#2/2/2009#,#9 Aug 2009 1:30:15 pm#或CDateTime(“9 Aug 2009 1:30:15 pm”)
 
范围数据类型
从2到5(包括2和5)
2 To 5
 
从2到5(不包括2包括5)
2 _To 5
 
小于或等于5
UpTo 5
 
小于5的所有数字
 
UpTo_ 5
日期范围
#Jan 5,2009# To #Dec 12,2009#
 
数组类型
[1,2,3]
[ ”a”,”b”,”c”]
2)  变量作用域
局部变量:
局部变量只限于单个公式以及该公式的单个求值。也就是说,无法从其他公式访问某个公式中的局部变量值。
局部变量声命格式:
 Local +  类型名称(带有后缀 Var)+ 该变量名声明的
例子:Local StringVar x := "hello";
 
全局变量:
全局变量使用相同的内存块在整个主报表中存储一个值。除子报表中的公式外,该值随后可用于所有声明此变量的公式。
全局变量声命格式:
Global+ 类型名称(带有后缀 Var)+ 该变量名声明的
例子:Global StringVar y;
默认情况下,也可以省略创建全局变量的 Global 关键字。
 
共享变量:
共享变量使用相同的内存块,在整个主报表及其所有子报表中存储变量值。因而,共享变量甚至比全局变量更普遍。若要使用共享变量,请在主报表内的公式中声明它
共享变量声命格式:
Shared+ 类型名称(带有后缀 Var)+ 该变量名声明的
例子:Shared StringVar y;
3)  运算符
算术运算符用于组合数字、数值变量、数值字段和数值函数以得到另一个数字。
算术运算符是加 (+)、减 (-)、乘 (*)、除 (/)、整除 (")、百分比 (%)、求余 (Mod)、求反 (-) 和求幂 (^)。
下面是优先顺序从高到低排列的算术运算符:
求幂 (^)
求反 (-)
乘、除和百分比 (*, /, %)
整除 (")
求余 (Mod)
加和减 (+, -)
 
比较运算符通常用于比较控制结构中的条件(如 If 表达式)的操作数。
比较运算符有等于 (=)、不等于 (<>)、小于 (<)、小于或等于 (<=)、大于 (>) 和大于或等于 (>=)。
 
布尔运算符通常与比较运算符一起使用,生成控制结构的条件。
按照从优先级最高到最低的顺序,布尔运算符有:Not、And、Or、Xor、Eqv 和 Imp。
 
一般情况下,Crystal Reports 在公式中遇到空值字段时,会立即停止公式求值而不产生任何值。若要处理公式中的空字段值,则必须使用专门用于处理空字段值的特殊函数进行显式处理。这些函数包括:IsNull、PreviousIsNull 或 NextIsNull。
 
4)  控制结构
If  表达式是最有用的控制结构之一。它使您得以在条件为 true 时对一系列表达式求值,而在条件不为 true 时对其他一系列表达式求值。
例子:
If {Employee.Dept} = "Sales" Then
{Employee.Salary} * 0.06
Else
{Employee.Salary} * 0.04
 
Select  表达式与 If 表达式相似。然而,有时可以使用 Select 表达式编写更清楚且重复少的公式。下例对 {客户.传真} 字段求值,以确定区号是北京区号 (010) 还是其他地方:
例子:
Select {Customer.Fax}[1 To 3]
Case "010" :
" 北京"
Default :
" 其他";
 
For  循环使您能够对一系列表达式多次求值。这不同于 If 和 Select 表达式,在 If 和 Select 语句中,程序在对公式求值时几乎同时传递每个语句。
如果事先知道需要对语句求值的次数,最好使用 For 循环。
使用 For 循环
Local NumberVar strLen :=0;
Local NumberVar i;
Local NumberVar sum;
For i := 1 To 100 Do
(
sum := sum +1i
);
 
While ... Do  循环对条件求值,如果条件为 true,则对 Do 后面的表达式求值。
完成对表达式的求值后,再次对该条件求值,如果条件为 true,则再次对 Do 后面的表达式求值。
它不断重复该过程,直到条件为 false 时为止。
 
Do ... While  循环对任何表达式求值一次。
然后对条件求值,如果条件为 true,则再次对表达式求值。该过程持续进行,直到条件为 false 时为止。
5)  函数
在Crystal Reports中,系统提供了很多函数,有数学、汇总、财务、字符串、日期/时间、日期范围、数组、类型转换、编程快捷方式、求值时间、打印状态、文档属性和附加函数。还有一些函数是条件格式设置公式专用函数。


















本文转自桂素伟51CTO博客,原文链接:http://blog.51cto.com/axzxs/149696 ,如需转载请自行联系原作者

相关文章
|
安全 jenkins 持续交付
Jenkins设置视图权限
Jenkins设置视图权限
|
Java C++ 开发者
【技术贴】if-else VS switch:谁才是Java条件判断的王者?
【6月更文挑战第14天】本文探讨了Java中if-else与switch语句的选择问题。if-else基于布尔逻辑,适合处理复杂逻辑,而switch在处理多分支特别是枚举类型时更高效。if-else在条件动态变化或复杂逻辑时更合适,switch则因其跳转表机制在固定选项中表现优秀。性能上,switch在大量选项时占优,但现代JVM优化后两者差异不大。选择时应考虑场景、可读性和维护性,灵活运用。理解两者特点,才能写出优雅高效的代码。
1103 0
|
存储 自然语言处理 C#
WPF技术之Binding
WPF(Windows Presentation Foundation)是微软推出的一种用于创建应用程序用户界面的框架。Binding(绑定)是WPF中的一个重要概念,它用于在界面元素和数据源之间建立关联。通过Binding,可以将界面元素(如文本框、标签、列表等)与数据源(如对象、集合、属性等)进行绑定,从而实现数据的双向传递和同步更新。
818 2
WPF技术之Binding
|
Kubernetes jenkins 持续交付
jenkins结合k8s构建流水线如何提升运行性能和构建效率
jenkins结合k8s构建流水线如何提升运行性能和构建效率
|
人工智能 监控 安全
智能机场系统:打造出行体验的未来
随着航空业的迅猛发展,机场作为出行的重要枢纽,必须不断提升自身的服务质量和效率。智能机场系统应运而生,为旅客提供更加便捷、智能化的出行体验。本文将从技术应用、服务优化和安全保障三个方面,全面介绍智能机场系统的特点和优势。
智能机场系统:打造出行体验的未来
|
SQL 存储 分布式计算
Storm与Spark、Hadoop三种框架对比
Storm与Spark、Hadoop这三种框架,各有各的优点,每个框架都有自己的最佳应用场景。所以,在不同的应用场景下,应该选择不同的框架。
Storm与Spark、Hadoop三种框架对比
|
C# UED 定位技术
WPF控件大全:初学者必读,掌握控件使用技巧,让你的应用程序更上一层楼!
【8月更文挑战第31天】在WPF应用程序开发中,控件是实现用户界面交互的关键元素。WPF提供了丰富的控件库,包括基础控件(如`Button`、`TextBox`)、布局控件(如`StackPanel`、`Grid`)、数据绑定控件(如`ListBox`、`DataGrid`)等。本文将介绍这些控件的基本分类及使用技巧,并通过示例代码展示如何在项目中应用。合理选择控件并利用布局控件和数据绑定功能,可以提升用户体验和程序性能。
633 0
|
存储 负载均衡 Cloud Native
【微服务系列笔记】Nacos
Nacos 是阿里巴巴开源的项目,用于构建云原生应用的动态服务发现、配置管理和服务管理平台。它支持动态服务发现、服务配置、服务元数据和流量管理,旨在更敏捷和方便地构建、交付和管理微服务平台。可作为注册中心与配置中心。
550 5
|
算法 C# UED
浅谈WPF之控件模板和数据模板
WPF不仅支持传统的Windows Forms编程的用户界面和用户体验设计,同时还推出了以模板为核心的新一代设计理念。在WPF中,通过引入模板,将数据和算法的“内容”和“形式”进行解耦。模板主要分为两大类:数据模板【Data Template】和控件模板【Control Template】。
564 8
|
数据库 微服务
AT与XA的区别
关于AT与XA的区别
986 0