ASP.NET设置数据格 式与String.Format使用总结
{0:d} YY-MM-DD
{0:p} 百分比00.00%
{0:N2} 12.68
{0:N0} 13
{0:c2} $12.68
{0:d} 3/23/2003
{0:T} 12:00:00 AM
{0: 男;;女}
DataGrid-数据格式设置表达式
数据格式设置表达式
.NET Framework 格 式设置表达式,它在数据显示在列中之前先应用于数据。此表达式由可选静态文本和用以下格式表示的格式说明符组成:
{0:format specifier}
零是参数索引,它指示列中要格式化的数据元素;因此,通常用零来指示第一个(且唯一的)元素。format specifier 前面有一个冒号 (:), 它由一个或多个字母组成,指示如何格式化数据。可以使用的格式说明符取决于要格式化的数据类型:日期、数字或其他类型。下表显示了不同数据类型的格式设置 表达式的示例。有关格式设置表达式的更多信息,请参见格式化类型。
格式设置表达式
应用于此数据类 型
说明
Price: {0:C}
numeric/decimal
显示“Price:”,后跟以货币格式表示的数字。货币格式取决于通过 Page 指令或 Web.config 文件中的区域性属性指定的区域性设置。
{0:D4}
integer(不 能和小数一起使用。)
在由零填充的四个字符宽的字段中显示整数。
{0:N2}%
numeric
显示精确到小数点后两位的数字,后跟“%”。
{0:000.0}
numeric/decimal
四舍五入到小数点后一位的数字。不到三位的数字用零填充。
{0:D}
date/datetime
长日期格式(“Thursday, August 06, 1996”)。日期格式取决于页或 Web.config 文件的区域性设置。
{0:d}
date/datetime
短日期格式(“12/31/99”)。
{0:yy-MM-dd}
date/datetime
用数字的年-月-日表示的日期(96-08-06)。
只读
当此列处于编辑模式时,该列中的数据是否显示在可 编辑的控件中。
2006-02-22 | asp.net数据格式的Format-- DataFormatString
我们在呈现数据的时候,不要将未经修饰过的数据呈现给使用者。例如金额一万元,如果我们直接显示「10000」,可能会导致使用者看成一千或十万,造成使用者阅读数据上的困扰。若我们将一万元润饰后输出为「NT$10,000」,不但让使比较好阅读,也会让使用者减少犯错的机会。
下列画面为润饰过的 结果:
上述数据除了将DataGrid Web 控件以颜色来区隔记录外,最主要将日期、单价以及小计这三个计字段的数据修饰的更容易阅读。要修 饰字段的输出,只要设定字段的DataFormatString 属性即可;其使用语法如下:
DataFormatString=" {0:格式字符串}"
我们知道在DataFormatString 中的 {0} 表示数据本身,而在冒号后面的格式字符串代表所们希望 数据显示的格式;另外在指定的格式符号后可以指定小数所要显示的位数。例如原来的数据为「12.34」,若格式设定为 {0:N1},则输出为 「12.3」。其常用的数值格式如下表所示:
格式字符串 资料 结果
"{0:C}" 12345.6789 $12,345.68
"{0:C}" -12345.6789 ($12,345.68)
"{0:D}" 12345 12345
"{0:D8}" 12345 00012345
"{0:E}" 12345.6789 1234568E+004
"{0:E10}" 12345.6789 1.2345678900E+004
"{0:F}" 12345.6789 12345.68
"{0:F0}" 12345.6789 12346
"{0:G}" 12345.6789 12345.6789
"{0:G7}" 123456789 1.234568E8
"{0:N}" 12345.6789 12,345.68
"{0:N4}" 123456789 123,456,789.0000
"Total: {0:C}" 12345.6789 Total: $12345.68
其常用的日期格式如下表所示:
格式 说明 输出格式
d 精简日期格式 MM/dd/yyyy
D 详细日期格 式 dddd, MMMM dd, yyyy
f 完整格 式 (long date + short time) dddd, MMMM dd, yyyy HH:mm
F
完整日期时间格式
(long date + long time)
dddd, MMMM dd, yyyy HH:mm:ss
g 一 般格式 (short date + short time) MM/dd/yyyy HH:mm
G 一般格 式 (short date + long time) MM/dd/yyyy HH:mm:ss
m,M 月日格式 MMMM dd
s 适 中日期时间格式 yyyy-MM-dd HH:mm:ss
t 精简时间格式 HH:mm
T 详细时间格式 HH:mm:ss
string.format 格式结果
String.Format
(C) Currency: . . . . . . . . ($123.00)
(D) Decimal:. . . . . . . . . -123
(E) Scientific: . . . . . . . -1.234500E+002
(F) Fixed point:. . . . . . . -123.45
(G) General:. . . . . . . . . -123
(N) Number: . . . . . . . . . -123.00
(P) Percent:. . . . . . . . . -12,345.00 %
(R) Round-trip: . . . . . . . -123.45
(X) Hexadecimal:. . . . . . . FFFFFF85
(d) Short date: . . . . . . . 6/26/2004
(D) Long date:. . . . . . . . Saturday, June 26, 2004
(t) Short time: . . . . . . . 8:11 PM
(T) Long time:. . . . . . . . 8:11:04 PM
(f) Full date/short time: . . Saturday, June 26, 2004 8:11 PM
(F) Full date/long time:. . . Saturday, June 26, 2004 8:11:04 PM
(g) General date/short time:. 6/26/2004 8:11 PM
(G) General date/long time: . 6/26/2004 8:11:04 PM
(M) Month:. . . . . . . . . . June 26
(R) RFC1123:. . . . . . . . . Sat, 26 Jun 2004 20:11:04 GMT
(s) Sortable: . . . . . . . . 2004-06-26T20:11:04
(u) Universal sortable: . . . 2004-06-26 20:11:04Z (invariant)
(U) Universal sortable: . . . Sunday, June 27, 2004 3:11:04 AM
(Y) Year: . . . . . . . . . . June, 2004
(G) General:. . . . . . . . . Green
(F) Flags:. . . . . . . . . . Green (flags or integer)
(D) Decimal number: . . . . . 3
(X) Hexadecimal:. . . . . . . 00000003
说明:
String.Format
将指定的 String 中的每个格式项替换为相应对象的值的文本等效项。
例子:
int iVisit = 100;
string szName = "Jackfled";
Response.Write(String.Format(" 您的帐号是:{0} 。访问了 {1} 次.", szName, iVisit));
String.Format 方法 (String,Object)
将指定的 String 中的格式项替换为指定的 Object 实例的值的文本等效项。
命名空间:System
程序集:mscorlib(在 mscorlib.dll 中)
语法
C#
public static string Format (
string format,
Object arg0
)
C# String.Format格式化实例代码
1. int a = 12345678;
2.
3. //格式为sring输出
4.
5. // Label1.Text = string.Format("asdfadsf{0}adsfasdf",a);
6.
7. // Label2.Text = "asdfadsf"+a.ToString()+"adsfasdf";
8.
9. // Label1.Text = string.Format("asdfadsf{0:C}adsfasdf",a);//asdfadsf¥1,234.00adsfasdf
10.
11.// Label2.Text = "asdfadsf"+a.ToString("C")+"adsfasdf";//asdfadsf¥1,234.00adsfasdf
12.
13. double b = 1234.12543;
14.
15. a = 12345678;
16.
17. //格式为特殊的string 样式输出
18.
19.// Label1.Text = string.Format("asdfadsf{0:C}adsfasdf",b);//asdfadsf¥1,234.13adsfasdf
20.
21.// Label2.Text = "asdfadsf"+b.ToString("C")+"adsfasdf";//asdfadsf¥1,234.13adsfasdf
22.
23.// Label1.Text = string.Format("{0:C3}",b);//¥1,234.125
24.
25.// Label2.Text = b.ToString("C3");//¥1,234.125
26.
27.// Label1.Text = string.Format("{0:d}",a);//十进制--12345678
28.
29.// Label2.Text = b.ToString("d");//十进制--相同的类型,转换报错
30.
31.// Label1.Text = string.Format("{0:e}",a);//指数--1.234568e+007
32.
33.// Label2.Text = b.ToString("e");//指数--1.234125e+003
34.
35.// Label1.Text = string.Format("{0:f}",a);//定点数--12345678.00
36.
37.// Label2.Text = b.ToString("f");//定点数--1234.13
38.
39.// Label1.Text = string.Format("{0:n}",a);//数值--12,345,678.00
40.
41.// Label2.Text = b.ToString("n");//数值--1,234.13
42.
43.// Label1.Text = string.Format("{0:x}",a);//十六进制--bc614e
44.
45.// Label2.Text = b.ToString("x");//16--带有小数不能转换,出错
46.
47.// Label1.Text = string.Format("{0:g}",a);//通用为最紧凑--12345678
48.
49.// Label2.Text = b.ToString("g");//通用为最紧凑--1234.12543
50.
51.// Label1.Text = string.Format("{0:r}",a);//转来转去不损失精度--整数不允许用,报错
52.
53.// Label2.Text = b.ToString("r");//转来转去不损失精度--1234.12543
54.
55.
56.
57. b = 4321.12543;
58.
59. a = 1234;
60.
61. //自定义模式输出:
62.
63.// 0 描述:占位符,如果可能,填充位
64.
65.// Label1.Text = string.Format("{0:000000}",a);// 001234
66.
67.// Label2.Text = string.Format("{0:000000}",b);// 004321
68.
69.// # 描述:占位符,如果可能,填充位
70.
71.// Label1.Text = string.Format("{0:#######}",a);// 1234
72.
73.// Label2.Text = string.Format("{0:#######}",b);// 4321
74.
75.// Label1.Text = string.Format("{0:#0####}",a);// 01234
76.
77.// Label2.Text = string.Format("{0:0#0000}",b);// 004321
78.
79.// . 描述:小数点
80.
81.// Label1.Text = string.Format("{0:000.000}",a);//1234.000
82.
83.// Label2.Text = string.Format("{0:000.000}",b);//4321.125
84.
85. b = 87654321.12543;
86.
87. a = 12345678;
88.
89.// , 描述:数字分组,也用于增倍器
90.
91.// Label1.Text = string.Format("{0:0,00}",a);// 12,345,678
92.
93.// Label2.Text = string.Format("{0:0,00}",b);// 87,654,32
94.
95.// Label1.Text = string.Format("{0:0,}",a);// 12346
96.
97.// Label2.Text = string.Format("{0:0,}",b);// 87654
98.
99.// Label1.Text = string.Format("{0:0,,}",a);// 12
100.
101. // Label2.Text = string.Format("{0:0,,}",b);// 88
102.
103. // Label1.Text = string.Format("{0:0,,,}",a);// 0
104.
105. // Label2.Text = string.Format("{0:0,,,}",b);// 0
106.
107. // % 描述:格式为百分数
108.
109. // Label1.Text = string.Format("{0:0%}",a);// 1234567800%
110.
111. // Label2.Text = string.Format("{0:#%}",b);// 8765432113%
112.
113. // Label1.Text = string.Format("{0:0.00%}",a);// 1234567800.00%
114.
115. // Label2.Text = string.Format("{0:#.00%}",b);// 8765432112.54%
116.
117. // 'abc' 描述:显示单引号内的文本
118.
119. // Label1.Text = string.Format("{0:'文本'0}",a);// 文本12345678
120.
121. // Label2.Text = string.Format("{0:文本0}",b);// 文本87654321
122.
123. // \ 描述:后跟1要打印字的字符,也用于转移符\n等
124.
125. // Label1.Text = string.Format("\"你好!\"");// "你好!"
126.
127. // Label2.Text = string.Format("\\c\\books\\new\\we.asp");//\c\books\new\we.asp
128.
129. // @描述:后跟要打印字的字符,
130.
131. // Label1.Text = string.Format(@"""你好!"""); // "你好!"要打印"则需要输入两对才可以
132.
133. // Label2.Text = string.Format(@"\c\books\new\we.asp");//\c\books\new\we.asp
134.
135. 格式 原始数据 结 果
136.
137. "{0:P}" 0.40 40%
138.
139. 数字 {0:N2} 12.36
140.
141. 数字 {0:N0} 13
142.
143. 货币 {0:c2} $12.36
144.
145. 货币 {0:c4} $12.3656
146.
147. 货币 "¥{0:N2}" ¥12.36
148.
149. 科学计数法 {0:E3} 1.23E+001
150.
151. 百分 数 {0:P} 12.25% P and p present the same.
152.
153. 日期 {0:D} 2006年11月25日
154.
155. 日期 {0:d} 2006-11-25
156.
157. 日期 {0:f} 2006年11月25 日 10:30
158.
159. 日期 {0:F} 2006年11月25 日 10:30:00
160.
161. 日 期 {0:s} 2006-11-26 10:30:00
162.
163. 时间 {0:T} 10:30:00
164.
165. DateTime dt = DateTime.Now;
166.
167. Label1.Text = dt.ToString();//2005-11-5 13:21:25
168.
169. Label2.Text = dt.ToFileTime().ToString();//127756416859912816
170.
171. Label3.Text = dt.ToFileTimeUtc().ToString();//127756704859912816
172.
173. Label4.Text = dt.ToLocalTime().ToString();//2005-11-5 21:21:25
174.
175. Label5.Text = dt.ToLongDateString().ToString();//2005年11月5日
176.
177. Label6.Text = dt.ToLongTimeString().ToString();//13:21:25
178.
179. Label7.Text = dt.ToOADate().ToString();//38661.5565508218
180.
181. Label8.Text = dt.ToShortDateString().ToString();//2005-11-5
182.
183. Label9.Text = dt.ToShortTimeString().ToString();//13:21
184.
185. Label10.Text = dt.ToUniversalTime().ToString();//2005-11-5 5:21:25
186.
187. Label1.Text = dt.Year.ToString();//2005
188.
189. Label2.Text = dt.Date.ToString();//2005-11-5 0:00:00
190.
191. Label3.Text = dt.DayOfWeek.ToString();//Saturday
192.
193. Label4.Text = dt.DayOfYear.ToString();//309
194.
195. Label5.Text = dt.Hour.ToString();//13
196.
197. Label6.Text = dt.Millisecond.ToString();//441
198.
199. Label7.Text = dt.Minute.ToString();//30
200.
201. Label8.Text = dt.Month.ToString();//11
202.
203. Label9.Text = dt.Second.ToString();//28
204.
205. Label10.Text = dt.Ticks.ToString();//632667942284412864
206.
207. Label11.Text = dt.TimeOfDay.ToString();//13:30:28.4412864
208.
209. Label1.Text = dt.ToString();//2005-11-5 13:47:04
210.
211. Label2.Text = dt.AddYears(1).ToString();//2006-11-5 13:47:04
212.
213. Label3.Text = dt.AddDays(1.1).ToString();//2005-11-6 16:11:04
214.
215. Label4.Text = dt.AddHours(1.1).ToString();//2005-11-5 14:53:04
216.
217. Label5.Text = dt.AddMilliseconds(1.1).ToString();//2005-11-5 13:47:04
218.
219. Label6.Text = dt.AddMonths(1).ToString();//2005-12-5 13:47:04
220.
221. Label7.Text = dt.AddSeconds(1.1).ToString();//2005-11-5 13:47:05
222.
223. Label8.Text = dt.AddMinutes(1.1).ToString();//2005-11-5 13:48:10
224.
225. Label9.Text = dt.AddTicks(1000).ToString();//2005-11-5 13:47:04
226.
227. Label10.Text = dt.CompareTo(dt).ToString();//0
228.
229. Label11.Text = dt.Add(?).ToString();//问号为一个时间段
230.
231. Label1.Text = dt.Equals("2005-11-6 16:11:04").ToString();//False
232.
233. Label2.Text = dt.Equals(dt).ToString();//True
234.
235. Label3.Text = dt.GetHashCode().ToString();//1474088234
236.
237. Label4.Text = dt.GetType().ToString();//System.DateTime
238.
239. Label5.Text = dt.GetTypeCode().ToString();//DateTime
240.
241. Label1.Text = dt.GetDateTimeFormats('s')[0].ToString();//2005-11-05T14:06:25
242.
243. Label2.Text = dt.GetDateTimeFormats('t')[0].ToString();//14:06
244.
245. Label3.Text = dt.GetDateTimeFormats('y')[0].ToString();//2005年11月
246.
247. Label4.Text = dt.GetDateTimeFormats('D')[0].ToString();//2005年11月5日
248.
249. Label5.Text = dt.GetDateTimeFormats('D')[1].ToString();//2005 11 05
250.
251. Label6.Text = dt.GetDateTimeFormats('D')[2].ToString();//星期六 2005 11 05
252.
253. Label7.Text = dt.GetDateTimeFormats('D')[3].ToString();//星期六 2005年11月5日
254.
255. Label8.Text = dt.GetDateTimeFormats('M')[0].ToString();//11月5日
256.
257. Label9.Text = dt.GetDateTimeFormats('f')[0].ToString();//2005年11月5日 14:06
258.
259. Label10.Text = dt.GetDateTimeFormats('g')[0].ToString();//2005-11-5 14:06
260.
261. Label11.Text = dt.GetDateTimeFormats('r')[0].ToString();//Sat, 05 Nov 2005 14:06:25 GMT
262.
263. Label1.Text = string.Format("{0:d}",dt);//2005-11-5
264.
265. Label2.Text = string.Format("{0:D}",dt);//2005年11月5日
266.
267. Label3.Text = string.Format("{0:f}",dt);//2005年11月5日 14:23
268.
269. Label4.Text = string.Format("{0:F}",dt);//2005年11月5日 14:23:23
270.
271. Label5.Text = string.Format("{0:g}",dt);//2005-11-5 14:23
272.
273. Label6.Text = string.Format("{0:G}",dt);//2005-11-5 14:23:23
274.
275. Label7.Text = string.Format("{0:M}",dt);//11月5日
276.
277. Label8.Text = string.Format("{0:R}",dt);//Sat, 05 Nov 2005 14:23:23 GMT
278.
279. Label9.Text = string.Format("{0:s}",dt);//2005-11-05T14:23:23
280.
281. Label10.Text string.Format("{0:t}",dt);//14:23
282.
283. Label11.Text = string.Format("{0:T}",dt);//14:23:23
284.
285. Label12.Text = string.Format("{0:u}",dt);//2005-11-05 14:23:23Z
286.
287. Label13.Text = string.Format("{0:U}",dt);//2005年11月5日 6:23:23
288.
289. Label14.Text = string.Format("{0:Y}",dt);//2005年11月
290.
291. Label15.Text = string.Format("{0}",dt);//2005-11-5 14:23:23
292.
293. Label16.Text = string.Format("{0:yyyyMMddHHmmssffff}",dt);
294.
295. stringstr1 =string.Format("{0:N1}",56789); //result: 56,789.0
296.
297. stringstr2 =string.Format("{0:N2}",56789); //result: 56,789.00
298.
299. stringstr3 =string.Format("{0:N3}",56789); //result: 56,789.000
300.
301. stringstr8 =string.Format("{0:F1}",56789); //result: 56789.0
302.
303. stringstr9 =string.Format("{0:F2}",56789); //result: 56789.00
304.
305. stringstr11 =(56789 / 100.0).ToString("#.##"); //result: 567.89
306.
307. stringstr12 =(56789 / 100).ToString("#.##"); //result: 567
308.
309. C 或 c
310.
311. 货币
312.
313. Console.Write("{0:C}", 2.5); //$2.50
314.
315. Console.Write("{0:C}", -2.5); //($2.50)
316.
317. D 或 d
318.
319. 十进制数
320.
321. Console.Write("{0:D5}", 25); //00025
322.
323. E 或 e
324.
325. 科学型
326.
327. Console.Write("{0:E}", 250000); //2.500000E+005
328.
329. F 或 f
330.
331. 固定点
332.
333. Console.Write("{0:F2}", 25); //25.00
334.
335. Console.Write("{0:F0}", 25); //25
336.
337. G 或 g
338.
339. 常规
340.
341. Console.Write("{0:G}", 2.5); //2.5
342.
343. N 或 n
344.
345. 数字
346.
347. Console.Write("{0:N}", 2500000); //2,500,000.00
348.
349. X 或 x
350.
351. 十六进制
352.
353. Console.Write("{0:X}", 250); //FA
354.
355. Console.Write("{0:X}", 0xffff); //FFFF