我正在使用SSRS 2008。 我想把日期显示为2011年1st日。但是"st"应该是上标,而不是像"1st"那样。
是否有方法可以在不安装任何自定义字体类型(其他字体类型)的情况下以上标形式显示 "st"、"nd"、"rd"和"th"?
我正在使用SSRS 2008。 我想把日期显示为2011年1st日。但是"st"应该是上标,而不是像"1st"那样。
是否有方法可以在不安装任何自定义字体类型(其他字体类型)的情况下以上标形式显示 "st"、"nd"、"rd"和"th"?
只需要从以下列表中复制并粘贴:
ABC⁰ ¹ ² ³ ⁴ ⁵ ⁶ ⁷ ⁸ ⁹ ⁺ ⁻ ⁼ ⁽ ⁾ ABC₀ ₁ ₂ ₃ ₄ ₅ ₆ ₇ ₈ ₉ ₊ ₋ ₌ ₍ ₎
ABCᵃ ᵇ ᶜ ᵈ ᵉ ᶠ ᵍ ʰ ⁱ ʲ ᵏ ˡ ᵐ ⁿ ᵒ ᵖ ʳ ˢ ᵗ ᵘ ᵛ ʷ ˣ ʸ ᶻ
ABCᴬ ᴮ ᴰ ᴱ ᴳ ᴴ ᴵ ᴶ ᴷ ᴸ ᴹ ᴺ ᴼ ᴾ ᴿ ᵀ ᵁ ᵂ
ABCₐ ₑ ᵢ ₒ ᵣ ᵤ ᵥ ₓ
ABC½ ¼ ¾ ⅓ ⅔ ⅕ ⅖ ⅗ ⅘ ⅙ ⅚ ⅛ ⅜ ⅝ ⅞ № ℠ ™ © ®
ABC^ ± ¶
也许...
您在使用String.Format时受到限制。字体大小和间距也是针对整个文本框的。因此,它不是“本地”的。
然而,上标是unicode,因此您可能可以通过一些复杂的表达式来连接字符来实现它。我建议使用自定义代码。
我没有尝试过这个方法,但这些文章提到了它。
="Some <b>bold</b> text"
可以工作);我不知道是否包括 <sup>
,或者可能是你可以样式化的 <span>
,因为我只用2005。 - Matt Gibson我并不是在这里寻求赞誉,因为上面的解决方案已经为您回答了问题,但为了初学者的缘故,我在我的报告中使用了一个代码函数。
所以在我的SQL中,假设我有一个数字字段,然后我添加一个新的字段OrdinalNumber:
SELECT ..., Number,
CASE WHEN (Number % 100) BETWEEN 10 AND 20 THEN 4
WHEN (Number % 10) = 1 THEN 1
WHEN (Number % 10) = 2 THEN 2
WHEN (Number % 10) = 3 THEN 3
ELSE 4 END AS OrdinalNumber,
...
然后我的代码函数:
Function OrdinalText(ByVal OrdinalNumber As Integer) As String
Dim result As String
Select Case OrdinalNumber
Case 1
result = "ˢᵗ"
Case 2
result = "ⁿᵈ"
Case 3
result = "ʳᵈ"
Case Else
result = "ᵗʰ"
End Select
Return result
结束函数
然后在报告文本框中使用表达式:
=CStr(Fields!Number.Value) & Code.OrdinalText(Fields!OrdinalNumber.Value)