博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

ASP.NET设置数据格 式与String.Format使用总结

Posted on 2010-11-12 21:46  itcfj  阅读(341)  评论(0编辑  收藏  举报

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