SSRS 2008中的文本框格式 - 中断行

时间:2013-10-02 16:13:40

标签: reporting-services formatting ssrs-2008

所以,说我有以下字符串

THIS IS STUFF (MORE STUFF)

如何在SSRS的文本框中将字符串格式化?

THIS IS STUFF
(MORE STUFF)

此数据是从查询中的单个字段中提取的,我将无法手动注入中断行。

此外,有时(更多东西)不在现场。

额外的例子:

  • STUFF AND THINGS
  • THINGS(STUFF)
  • 东西和东西(更多东西)
  • 2 个答案:

    答案 0 :(得分:6)

    您需要在字符串中插入换行符,即将文本框表达式设置为:

    ="THIS IS STUFF" & vbcrlf & "(MORE STUFF)"
    

    所以表达式在一个文本框中:

    enter image description here

    将呈现为:

    enter image description here

    即使字符串可以放在一行上,你也可以看到换行符。

    在评论后修改

    好的,我们需要在报告级别处理各种现有字符串。

    为此,我建议使用自定义代码,即类似函数:

    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)
    

    在文本框表达式中或作为数据集中的计算字段。上述内容适用于您的数据:

    enter image description here

    enter image description here

    答案 1 :(得分:0)

    我在做项目时遇到了这个问题。我想分享我的步骤。通过选择表达式并根据需要格式化,在文本框中创建单独的placehloders。您可以通过将另一个项目(另一个占位符)移动到下一行(通过按下键盘输入)轻松添加额外的行 在这里,我在列表中创建了单独的占位符,根据需要提供了名称和格式。 enter image description here