所以,说我有以下字符串
THIS IS STUFF (MORE STUFF)
如何在SSRS的文本框中将字符串格式化?
THIS IS STUFF
(MORE STUFF)
此数据是从查询中的单个字段中提取的,我将无法手动注入中断行。
此外,有时(更多东西)不在现场。
额外的例子:
答案 0 :(得分:6)
您需要在字符串中插入换行符,即将文本框表达式设置为:
="THIS IS STUFF" & vbcrlf & "(MORE STUFF)"
所以表达式在一个文本框中:
将呈现为:
即使字符串可以放在一行上,你也可以看到换行符。
在评论后修改
好的,我们需要在报告级别处理各种现有字符串。
为此,我建议使用自定义代码,即类似函数:
Function SplitString (fieldValue As String) As String
If IsDBNull(fieldValue) OrElse IsNothing(fieldValue) Then
SplitString = ""
Else If InStr(fieldValue, "(") > 0
SplitString = RTrim(Left(fieldValue, InStr(fieldValue, "(") - 1)) & _
vbcrlf & Right(fieldValue, Len(fieldValue) - InStr(fieldValue, "(") + 1)
Else
SplitString = fieldValue
End If
End Function
我建议这样做,因为SSRS表达式是众所周知的脆弱,并且缺少短路意味着对一个字符串起作用的东西可能会在另一个字符串上显示#Error
。您可以使用大量IIf
语句解决此问题,但自定义代码更简洁,更易于理解。
您可以使用如下表达式调用该函数:
=Code.SplitString(Fields!MYFIELD.Value)
在文本框表达式中或作为数据集中的计算字段。上述内容适用于您的数据:
答案 1 :(得分:0)