Crystal Reports Designer  

Select 表达式(Crystal 语法)

Select 表达式与 If 表达式相似。然而,有时可以使用 Select 表达式编写更清楚且重复少的公式。下例对 {客户.传真} 字段求值,以确定区号是美国华盛顿州的区号 (206, 360, 509) 还是加拿大不列颠哥伦比亚省的区号 (604, 250):

//Select example 1
Select {Customer.Fax}[1 To 3]
   Case "604", "250" :
      "BC"
   Case "206", "509", "360" :
      "WA"
   Default :
      "";

紧跟在 Select 关键字之后的表达式称为 Select 条件。在上例中,Select 条件是 {客户.传真}[1 To 3]。Select 表达式试图找出与 Select 条件匹配的第一个 Case,然后为该 Case 执行冒号后面的表达式。如果前面的情况都与 Select 条件不匹配,则匹配 Default 情况。注意 Default 后面也有个冒号。

//Same effect as Select example 1
Local StringVar areaCode := {Customer.Fax}[1 To 3];
If areaCode In ["604", "250"] Then
   "BC"
Else If areaCode In ["206", "509", "360"] Then
   "WA"
Else
   "";

示例

下面的公式将电影获得的奥斯卡提名分为“低”、“中”、“高”或“极高”几类,并在执行过程中显示 Case 标签后的表达式列表的一些可能匹配项。

//Select example 2
Select {movie.NOM}
   Case 1,2,3, Is < 1 :
   (
      //Can have expression lists by using
      //parentheses
      10 + 20;
      "low"
   )
   Case 4 To 6, 7, 8, 9 :
      "medium"
   Case 10 :
      "high"
   Default :
      "extreme"

Select 表达式的 Default 子句是可选的。如果没有 Default 子句,并且没有匹配的情况,则 Select 表达式将返回其表达式类型的默认值。例如,如果在上例中省略 Default 子句,并且 {电影.提名} = 11,则将返回空字符串 ""。Select 表达式是一个表达式,有关 If 表达式的更多详细信息一节中的相似注释也适用于它。

另请参见

If 表达式 | 控制结构 | For 循环