實例:
用戶輸入一個日期,要求輸出這個日期是星期幾和在這一年中的第幾天:
Console.WriteLine("{0}是星期{1}", dt.ToShortDateString(), str);
Console.WriteLine("{0}是這一年的第{1}天", dt.ToLongDateString(), dt.DayOfYear);
上述代碼運行的結果如下
顯示當前時期和時間的不同合格:
Console.WriteLine("短日期字符串表示現在時間是:{0}", DateTime.Now.Date.ToShortDateString());
Console.WriteLine("長日期字符串表示現在時間是:{0}", DateTime.Now.Date.ToLongDateString ());
上述代碼的運行結果如下
日期類型(DateTime)格式化
方法一:
使用DateTime.ToString(format, DateTimeFormatInfo.InvariantInfo)
示例代碼:
參數format格式詳細用法:
格式字符關聯屬性/說明
dShortDatePattern
DLongDatePattern
f完整日期和時間(長日期和短時間)
FFullDateTimePattern(長日期和長時間)
g常規(短日期和短時間)
G常規(短日期和長時間)
m、MMonthDayPattern
r、RRFC1123Pattern
s使用當地時間的SortableDateTimePattern(基于ISO8601)
tShortTimePattern
TLongTimePattern
uUniversalSortableDateTimePattern用于顯示通用時間的格式
U使用通用時間的完整日期和時間(長日期和長時間)
y、YYearMonthPattern
下面列出可被合并以構造自定義模式的模式:
d月中的某一天。一位數的日期沒有前導零。
dd月中的某一天。一位數的日期有一個前導零。
ddd周中某天的縮寫名稱,在AbbreviatedDayNames中定義。
dddd周中某天的完整名稱,在DayNames中定義。
M月份數字。一位數的月份沒有前導零。
MM月份數字。一位數的月份有一個前導零。
MMM月份的縮寫名稱,在AbbreviatedMonthNames中定義。
MMMM月份的完整名稱,在MonthNames中定義。
y不包含紀元的年份。如果不包含紀元的年份小于10,則顯示不具有前導零的年份。
yy不包含紀元的年份。如果不包含紀元的年份小于10,則顯示具有前導零的年份。
yyyy包括紀元的四位數的年份。
gg時期或紀元。如果要設置格式的日期不具有關聯的時期或紀元字符串,則忽略該模式。
h12小時制的小時。一位數的小時數沒有前導零。
hh12小時制的小時。一位數的小時數有前導零。
H24小時制的小時。一位數的小時數沒有前導零。
HH24小時制的小時。一位數的小時數有前導零。
m分鐘。一位數的分鐘數沒有前導零。
mm分鐘。一位數的分鐘數有一個前導零。
s秒。一位數的秒數沒有前導零。
ss秒。一位數的秒數有一個前導零。
f秒的小數精度為一位。其余數字被截斷。
ff秒的小數精度為兩位。其余數字被截斷。
fff秒的小數精度為三位。其余數字被截斷。
ffff秒的小數精度為四位。其余數字被截斷。
fffff秒的小數精度為五位。其余數字被截斷。
ffffff秒的小數精度為六位。其余數字被截斷。
fffffff秒的小數精度為七位。其余數字被截斷。
t在AMDesignator或PMDesignator中定義的AM/PM指示項的第一個字符(如果存在)。
tt在AMDesignator或PMDesignator中定義的AM/PM指示項(如果存在)。
z時區偏移量(“+”或“-”后面僅跟小時)。一位數的小時數沒有前導零。例如,太平洋標準時間是“-8”。
zz時區偏移量(“+”或“-”后面僅跟小時)。一位數的小時數有前導零。例如,太平洋標準時間是“-08”。
zzz完整時區偏移量(“+”或“-”后面跟有小時和分鐘)。一位數的小時數和分鐘數有前導零。例如,太平洋標準時間是“-08:00”。
:在TimeSeparator中定義的默認時間分隔符。
/在DateSeparator中定義的默認日期分隔符。
%c其中c是格式模式(如果單獨使用)。如果格式模式與原義字符或其他格式模式合并,則可以省略“%”字符。
/c其中c是任意字符。照原義顯示字符。若要顯示反斜杠字符,請使用“//”。
方法二:
新聞熱點
疑難解答