C#日期函数使用技巧大全

 杜思波技术大讨论2009

 

这些时间函数用法很常用,也很实用,相信对大家都有帮助,杜思波推荐的东西哦!不能错过阿。

  1. //今天
  2. DateTime.Now.Date.ToString();
  3. //昨天
  4. DateTime.Now.AddDays(-1).ToString();
  5. //明天
  6. DateTime.Now.AddDays(1).ToString();
  7. //本周第1天及最后1天 (要注意的是这里的每一周是从周日始至周六止)
  8. DateTime.Today.AddDays (-(int)DateTime.Today.DayOfWeek).ToString();
  9. DateTime.Today.AddDays (6 -(int)DateTime.Today.DayOfWeek).ToString();
  10. //上周, 一周是7天,上周就是本周再减去7天
  11. DateTime.Today.AddDays (-(int)DateTime.Today.DayOfWeek - 7).ToString();
  12. DateTime.Today.AddDays (6 -(int)DateTime.Today.DayOfWeek - 7).ToString();
  13. //下周
  14. DateTime.Today.AddDays (-(int)DateTime.Today.DayOfWeek + 7).ToString();
  15. DateTime.Today.AddDays (6 -(int)DateTime.Today.DayOfWeek + 7).ToString();
  16. 巧用C#裡ToString的字符格式化
  17. //本月第1天及最后1天
  18. DateTime.Now.ToString("yyyy-MM-01");
  19. DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).AddDays(-1).ToString();
  20. //上个月第1天及最后1天
  21. DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1).ToString();
  22. DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1).ToString();
  23. //下个月第1天及最后1天
  24. DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).ToString();
  25. DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(2).AddDays(-1).ToString();
  26. //今年第1天
  27. DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).ToString();
  28. //今年最后1天
  29. DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).AddDays(-1).ToString();
  30. //去年第1天及最后1天
  31. DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(-1).ToString();
  32. DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddDays(-1).ToString();
  33. //明年第1天及最后1天
  34. DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).ToString();
  35. DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(2).AddDays(-1).ToString();
  36. //本季,一年四个季度,一季度三月
  37. //先把日期推到本季度第一月,然后这个月的第一天就是本季度的第一天了
  38. DateTime.Now.AddMonths(0 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01");
  39. //本季度的最後一天就是下季度的第一天減一
  40. DateTime.Parse(DateTime.Now.AddMonths(3 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01")).AddDays(-1).ToString();
  41. //下季
  42. DateTime.Now.AddMonths(3 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01");
  43. DateTime.Parse(DateTime.Now.AddMonths(6 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01")).AddDays(-1).ToString();
  44. //上季
  45. DateTime.Now.AddMonths(-3 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01");
  46. DateTime.Parse(DateTime.Now.AddMonths(0 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01")).AddDays(-1).ToString(); 
  47. 其他格式获取
  48. DateTime dt = DateTime.Now;
  49. Label1.Text = dt.ToString();//2005-11-5 13:21:25
  50. Label2.Text = dt.ToFileTime().ToString();//127756416859912816
  51. Label3.Text = dt.ToFileTimeUtc().ToString();//127756704859912816
  52. Label4.Text = dt.ToLocalTime().ToString();//2005-11-5 21:21:25
  53. Label5.Text = dt.ToLongDateString().ToString();//2005年11月5日
  54. Label6.Text = dt.ToLongTimeString().ToString();//13:21:25
  55. Label7.Text = dt.ToOADate().ToString();//38661.5565508218
  56. Label8.Text = dt.ToShortDateString().ToString();//2005-11-5
  57. Label9.Text = dt.ToShortTimeString().ToString();//13:21
  58. Label10.Text = dt.ToUniversalTime().ToString();//2005-11-5 5:21:25
  59. ?2005-11-5 13:30:28.4412864
  60. Label1.Text = dt.Year.ToString();//2005
  61. Label2.Text = dt.Date.ToString();//2005-11-5 0:00:00
  62. Label3.Text = dt.DayOfWeek.ToString();//Saturday
  63. Label4.Text = dt.DayOfYear.ToString();//309
  64. Label5.Text = dt.Hour.ToString();//13
  65. Label6.Text = dt.Millisecond.ToString();//441
  66. Label7.Text = dt.Minute.ToString();//30
  67. Label8.Text = dt.Month.ToString();//11
  68. Label9.Text = dt.Second.ToString();//28
  69. Label10.Text = dt.Ticks.ToString();//632667942284412864
  70. Label11.Text = dt.TimeOfDay.ToString();//13:30:28.4412864
  71. Label1.Text = dt.ToString();//2005-11-5 13:47:04
  72. Label2.Text = dt.AddYears(1).ToString();//2006-11-5 13:47:04
  73. Label3.Text = dt.AddDays(1.1).ToString();//2005-11-6 16:11:04
  74. Label4.Text = dt.AddHours(1.1).ToString();//2005-11-5 14:53:04
  75. Label5.Text = dt.AddMilliseconds(1.1).ToString();//2005-11-5 13:47:04
  76. Label6.Text = dt.AddMonths(1).ToString();//2005-12-5 13:47:04
  77. Label7.Text = dt.AddSeconds(1.1).ToString();//2005-11-5 13:47:05
  78. Label8.Text = dt.AddMinutes(1.1).ToString();//2005-11-5 13:48:10
  79. Label9.Text = dt.AddTicks(1000).ToString();//2005-11-5 13:47:04
  80. Label10.Text = dt.CompareTo(dt).ToString();//0
  81. //Label11.Text = dt.Add(?).ToString();//问号为一个时间段
  82. Label1.Text = dt.Equals("2005-11-6 16:11:04").ToString();//False
  83. Label2.Text = dt.Equals(dt).ToString();//True
  84. Label3.Text = dt.GetHashCode().ToString();//1474088234
  85. Label4.Text = dt.GetType().ToString();//System.DateTime
  86. Label5.Text = dt.GetTypeCode().ToString();//DateTime
  87. Label1.Text = dt.GetDateTimeFormats('s')[0].ToString();//2005-11-05T14:06:25
  88. Label2.Text = dt.GetDateTimeFormats('t')[0].ToString();//14:06
  89. Label3.Text = dt.GetDateTimeFormats('y')[0].ToString();//2005年11月
  90. Label4.Text = dt.GetDateTimeFormats('D')[0].ToString();//2005年11月5日
  91. Label5.Text = dt.GetDateTimeFormats('D')[1].ToString();//2005 11 05
  92. Label6.Text = dt.GetDateTimeFormats('D')[2].ToString();//星期六 2005 11 05
  93. Label7.Text = dt.GetDateTimeFormats('D')[3].ToString();//星期六 2005年11月5日
  94. Label8.Text = dt.GetDateTimeFormats('M')[0].ToString();//11月5日
  95. Label9.Text = dt.GetDateTimeFormats('f')[0].ToString();//2005年11月5日 14:06
  96. Label10.Text = dt.GetDateTimeFormats('g')[0].ToString();//2005-11-5 14:06
  97. Label11.Text = dt.GetDateTimeFormats('r')[0].ToString();//Sat, 05 Nov 2005 14:06:25 GMT
  98. Label1.Text =? string.Format("{0:d}",dt);//2005-11-5
  99. Label2.Text =? string.Format("{0:D}",dt);//2005年11月5日
  100. Label3.Text =? string.Format("{0:f}",dt);//2005年11月5日 14:23
  101. Label4.Text =? string.Format("{0:F}",dt);//2005年11月5日 14:23:23
  102. Label5.Text =? string.Format("{0:g}",dt);//2005-11-5 14:23
  103. Label6.Text =? string.Format("{0:G}",dt);//2005-11-5 14:23:23
  104. Label7.Text =? string.Format("{0:M}",dt);//11月5日
  105. Label8.Text =? string.Format("{0:R}",dt);//Sat, 05 Nov 2005 14:23:23 GMT
  106. Label9.Text =? string.Format("{0:s}",dt);//2005-11-05T14:23:23
  107. Label10.Text = string.Format("{0:t}",dt);//14:23
  108. Label11.Text = string.Format("{0:T}",dt);//14:23:23
  109. Label12.Text = string.Format("{0:u}",dt);//2005-11-05 14:23:23Z
  110. Label13.Text = string.Format("{0:U}",dt);//2005年11月5日 6:23:23
  111. Label14.Text = string.Format("{0:Y}",dt);//2005年11月
  112. Label15.Text = string.Format("{0}",dt);//2005-11-5 14:23:23?
  113. Label16.Text = string.Format("{0:yyyyMMddHHmmssffff}",dt);  //yyyymm等可以设置,比如Label16.Text = string.Format("{0:yyyyMMdd}",dt);  

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值