正则表达式

时间:2015-11-30 13:08:06

标签: regex reporting-services ssrs-2012 sentencecase

我想将SSRS报告中的字段转换为句子例如:

  一些测试句。第二句。

应转换为:

  

一些测试句。第二句话。

我目前正在尝试使用正则表达式:

=System.Text.RegularExpressions.Regex.Replace(
 IIf(IsNothing(Fields!Title.Value), "", LCase(Fields!Title.Value)),
 "(^[a-z])|\.\s+(.)",
 UCase("$1")
)

以上的rejex失败了。似乎部分:UCase("$1")无效。我得到的是整个字符串小写。

1 个答案:

答案 0 :(得分:2)

如评论中所述,SSRS不会资本化#1; $ 1"标识符,因为它将它作为文字字符串。

作为解决方法,我建议您使用此自定义代码:

转到报告属性/代码并输入以下代码:

Function ProperCase(InputString as String) As String
         Dim i as Integer
         If InputString  <> "" Then
            Mid(InputString , 1, 1) = UCase(Mid(InputString , 1, 1))
            For i = 1 To Len(InputString) - 1
               If Mid(InputString, i, 2) = "." + " " Then
                  Mid(InputString, i + 2, 1) = UCase(Mid(InputString, i + 2, 1))
               End If
            Next
            Return InputString
         End If
End Function

要使用它,请在文本框中调用它,如下所示:

=Code.ProperCase(LCase(Fields!Title.Value))

我测试了这个字符串:

some test sentence. second Sentence. SHOULD THIS BE CAPITALIZED?

它返回了:

Some test sentence. Second Sentence. Should this be capitalized?

让我知道这可以帮到你。