SSRS 數值和日期格式

2021-09-06 03:30:34 字數 3393 閱讀 5325

需要注意的是,若是文字方塊內輸入的是數字或是日期,此時可以利用格式化字

串的方式來更新文字方塊的 「format」 屬性,以轉換為指定為數字或日期的

格式,想必各位並不陌生,因為之前的範例中已經利用「c0」格式字串來調整

銷售金額的顯示格式了,以下我們會針對格式字串更更深入的介紹,首先介紹數

值常用的格式字串。

格式化字串 說明

c 或 c 顯示作業系統中地區選項所設定地區之貨幣格式,包含

千分位以及小數點。

d 或 d 顯示十進位數字,不包括千分號。位數不足前方補零,

只支援整數格式。

e 或 e 以科學記號顯示數字,可指定小數字數

f 或 f 顯示十進位數字,不包括千分號,可以指定小數字數長

度,不足者補零。

g 或 g 以科學記號顯示數字,不可指定小數字數

n 或 n 數字,包含千分位符號

p 或 p 百分比,可指定小數字數,含千分位

x 或 x 十六位數字,只支援整數資料

表4.7:數值常用的格式字串列表

除了少數像是d、g 或者是x 這類只支援整數格式的格式字串之外,大多數的

格式字串同時可以指定小數點的精確位數。指定小數字數的方法很簡單,只需要

在格式字串後直接接上欲指定的小數字數即可。舉例來說,我們希望數值變成小

數下兩位的貨幣格式,那麼就只要將format 屬性設為c2 即可。

關於數值格式的設定,可以參考圖4.64 的範例結果:

圖4.64:數值格式化字串

除了以上的常用格式字串之外,也可以自訂格式化字串,

自定數值格式字串 格式

# 代表數值位數

0 代表數值固定位數

. 小數點

, 千分號

% 百分比符號

表4.8:自定數值格式字串列表

舉例來說,如果我們希望數值保更千分位符號,且小數點下兩位,則此時就要在

format 屬性中填入=」#,###.##」,此時,原來數值「1234.567」就會被格式化為

「1,234.57」。格式化字串「#」與「0」之間最大的差別在於,如果使用「#」,

當位數不足時,並不會自動補齊,而如果使用「0」,則會在不足位數之處補零。

舉例來說數值「1234.5」的format 設為=」#,###.###」時,則呈現結果為「1,234.5」;

但若是format 設為=」0,000.000」時,則呈現結果為「1,234.500」。此外要注意

的是,如果是使用預設的常見格式字串時,只要直接在format 屬性輸入格式自

串即可,但是如果是使用客製化格式字串時,必頇開頭加上等號,同時格式字串

前後加上雙引號。

日期的格式化就顯的更加複雜,因為涉及到以符號顯示還是以文字顯示的問題。

以下是預設常用的日期格式字串。

日期格式化字串 說明

d 簡短日期

d 完整日期(出現該語系完整年月日)

t 簡短時間(時分)

t 完整時間(時分秒)

f 完整日期/時間(出現該語系完整年月日)

f 完整日期/時間(出現該語系完整年月日,時間到時分

秒)g 一般日期/時間

g 一般日期/時間 (時間到時分秒)

r 或 r rfc1123 模式

表4.9:日期格式字串列表

參考範例4.5.2-日期格式化字串,設定後呈現結果如圖4.66:

圖4.65:日期格式化字串

除了使用基本的日期格式化字串之外,還可以使用自訂日期格式字串來呈現客製

化的時間格式。

自定日期格式字串 格式

d 日期

dd 日期,不足二位數者前方補零

ddd 星期幾

dddd 星期幾完整名稱

m 月份

mm 月份,不足二位數者補零

mmm 完整月份名

y 年份

yyyy 完整西元年份

表4.10:自定日期格式字串列表

舉例來說,我們希望日期格式呈現「2004-01-01」的話,就只要在format 屬性

處撰寫=」yyyy-mm-dd」即可。如果要呈現的是「2004/1/1」,則要將format 的運

算式改寫為=」yyyy/m/d」。

除此之外還更兩個文字方塊屬性會影響到日期格式的呈現,那就是calendar 以

及language。calendar 屬性是會自動將日期轉換成指定國家曆法的對應年份。

基本上,calendar 屬性的預設曆法為gregorian(羅馬舊教曆法,就是目前通

用的西元曆法),如果我們希望將西元曆法換算為民國紀元,那只需要將

calendar 的屬性指定為taiwan 即可。舉例來說,如果希望日期呈現「民國93

年1 月1 日」格式的話,那只要做以下設定即可:

 calendar =taiwan

 format=d

而language 影響的範圍則是複寫使用者作業系統的地區設定,來呈現地區客製

化的格式呈現。舉例來說,當language 屬性設為「中文(台灣)」時,數值格式

字串c 前方呈現。

格式字串 language「中文(台灣)」 language「英文(美國)」

c nt$ $

mmm 一月 jan

ddd 星期一 mon

dddd 星期一 monday

表4.11:language 設定

請注意,calendar 的設定項會受到language 所影響。舉例來說,當language

設為「中文(台灣)」時,calendar 屬性就不得設為「japan」。如果您希望設境

特殊國家的曆法時,必頇事先將language 設定為正確的語系。

基本上ssrs 的格式字串原則與visual basic .net 完全相同,如果更開發

vb .net 經驗的人一定覺得很熟悉,事實上,格式字串的規則相當複雜,在此

只是列出一些比較常用的部份,如果各位更興趣的話還可以自行參考坊間介紹

vb .net 程式撰寫的書籍。

在新增「文字方塊」時,我們會發現,預設的大小是固定的,若想改變「文字方

塊」的大小,可直接拖拉「文字方塊」的邊框來調整,或是利用屬性視窗的「size」

屬性的「width」與「height」來設定,使用屬性設定比較可以確保文字方塊的

大小以便排列整齊。

當文字方塊內呈現的是資料庫字段內容或計算後產生的結果)時,通常都無法預

期資料內容的長度是否會超過「文字方塊」的大小,這時可將「cangrow」屬

性設定為「true」,「文字方塊」會隨著其中的內容橫向延展,而高度將會保持原

狀不會改變。相反的,也更可能顯示的文字內容小於「文字方塊」,大部分的情

況下,都會讓「文字方塊」維持原狀,但如果在特別的情況下,將「canshrink」

屬性設為「true」,可達到自動縮小「文字方塊」寬度的效果

shell日期 格式和計算

man date 可以直接檢視日期的格式 列出常用的年月日 date d 2012 04 10 1 day y m d 2012 04 09 date d 2012 04 10 1 day y m d 2012 04 11 date d 1 week y m d 2012 04 15 date d ...

IBM SQL日期和時間格式

說起日期,這個讓很多人比較糾結的格式,最起碼我一直對這個有點恐懼,每次 涉及到日期的時候就感覺很陌生。總結了一下sql的一些日期和時間格式 格式名日期格式 日期範例 時間格式 日期範例 美國mm dd yyyy 5 19 1960 hh mm am pm 2 18 pm 歐洲dd.mm.yyyy 1...

JS 封裝和整理 日期格式轉換和日期計算

1 日期格式轉換 用法說明 直接呼叫 輸入時間 毫秒數 和 格式 formatdate new date gettime formatdate new date gettime yy年mm月dd日 formatdate new date gettime 今天是yy mm dd hh mm ss fu...