有时辰需要按照当前时刻,断定其它的都没有什么难度,只是本季度稍稍麻烦些。因为一年有四个季度,可以按照当前月份,获得本季度第一个月的月份,然后这个月的第一天,就是本季度的第一天了

DateTime dt = DateTime.Now;  //当前时刻

DateTime startWeek = dt.AddDays(1 - Convert.ToInt32(dt.DayOfWeek.ToString("d"))); //本周周一
DateTime endWeek = startWeek.AddDays(6);  //本周周日

DateTime startMonth = dt.AddDays(1 - dt.Day);  //本月月初
DateTime endMonth = startMonth.AddMonths(1).AddDays(-1);  //本月月末
DateTime endMonth = startMonth.AddDays((dt.AddMonths(1) - dt).Days - 1);  //本月月末

DateTime startQuarter = dt.AddMonths(0 - (dt.Month - 1) % 3).AddDays(1 - dt.Day);  //本季度初
DateTime endQuarter = startQuarter.AddMonths(3).AddDays(-1);  //本季度末

DateTime startYear = new DateTime(dt.Year, 1, 1);  //今年岁首
DateTime endYear = new DateTime(dt.Year, 12, 31);  //今年年尾
至于昨天、明天、上周、上月、上季度、上年度等等,只要AddDays()、AddMonths()、AddYears()这几种方法组合一下就可以了。

C#中datetime的操作
人人在做报表或查询的时辰城市有给用户预设一些可选的日期领域
//现在年度发卖额、本季度利润、本月新增客户
//C#里内置的DateTime根本上都可以实现这些功效,巧用DateTime会使你措置赏罚这些事来变轻松多了 
//今天
DateTime.Now.Date.ToShortDateString();
//昨天,就是今天的日期减一
DateTime.Now.AddDays(-1).ToShortDateString();
//明天,同理,加一
DateTime.Now.AddDays(1).ToShortDateString();
//本周(要知道本周的第一天就得先知道今天是礼拜几,从而得知本周的第一天就是几天前的那一天,要留心的是这里的每一周是从周日始至周六止
DateTime.Now.AddDays(Convert.ToDouble((0 - Convert.ToInt16(DateTime.Now.DayOfWeek)))).ToShortDateString();
DateTime.Now.AddDays(Convert.ToDouble((6 - Convert.ToInt16(DateTime.Now.DayOfWeek)))).ToShortDateString();
//假如你还不年夜白,再看一下中文显示礼拜几的方法就该当懂了
//因为DayOfWeek返回的是数字的礼拜几,我们要把它转换成汉字利便我们浏览,有些人可能会用switch来一个一个地对照,其实不用那么麻烦的             
string[] Day = new string[] { "礼拜日", "礼拜一", "礼拜二", "礼拜三", "礼拜四", "礼拜五", "礼拜六" };
Day[Convert.ToInt16(DateTime.Now.DayOfWeek)];

//上周,同理,一个周是7天,上周就是本周再减往7天,下周也是一样
DateTime.Now.AddDays(Convert.ToDouble((0 - Convert.ToInt16(DateTime.Now.DayOfWeek))) - 7).ToShortDateString();
DateTime.Now.AddDays(Convert.ToDouble((6 - Convert.ToInt16(DateTime.Now.DayOfWeek))) - 7).ToShortDateString();
//下周
DateTime.Now.AddDays(Convert.ToDouble((0 - Convert.ToInt16(DateTime.Now.DayOfWeek))) + 7).ToShortDateString();
DateTime.Now.AddDays(Convert.ToDouble((6 - Convert.ToInt16(DateTime.Now.DayOfWeek))) + 7).ToShortDateString();
//本月,良多人城市说本月的第一天嘛确定是1号,最后一天就是下个月一号再减一天。当然这是对的
//一般的写法
DateTime.Now.Year.ToString() + DateTime.Now.Month.ToString() + "1"; //第一天
DateTime.Parse(DateTime.Now.Year.ToString()  + DateTime.Now.Month.ToString() +  "1").AddMonths(1).AddDays(-1).ToShortDateString();//最后一天

//巧用C#里ToString的字符名目化更简洁
DateTime.Now.ToString("yyyy-MM-01");
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).AddDays(-1).ToShortDateString();

//上个月,减往一个月份
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();
//下个月,加往一个月份
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(2).AddDays(-1).ToShortDateString();
//7天后
DateTime.Now.Date.ToShortDateString();
DateTime.Now.AddDays(7).ToShortDateString();
//7天前
DateTime.Now.AddDays(-7).ToShortDateString();
DateTime.Now.Date.ToShortDateString();

//今年度,用ToString的字符名目化我们也很等闲地算出今年度的第一天和最后一天
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).AddDays(-1).ToShortDateString();
//上年度,不用再诠释了吧
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(-1).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddDays(-1).ToShortDateString();
//下年度
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(2).AddDays(-1).ToShortDateString();

//本季度,良多人城市感应这里难点,需要写个长长的过程来剖断。其实不用的,我们都知道一年四个季度,一个季度三个月
//首先我们先把日期推到本季度第一个月,然后这个月的第一天就是本季度的第一天了
DateTime.Now.AddMonths(0 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01");
//同理,本季度的最后一天就是下季度的第一天减一
DateTime.Parse(DateTime.Now.AddMonths(3  - ((DateTime.Now.Month - 1) %  3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();
//下季度,信任你们都知道了。。。。收工
DateTime.N

  1. DateTime dt = DateTime.Now;
  2.  
  3. dt.ToString();//2005-11-5 13:21:25
  4. dt.ToFileTime().ToString();//127756416859912816
  5. dt.ToFileTimeUtc().ToString();//127756704859912816
  6. dt.ToLocalTime().ToString();//2005-11-5 21:21:25
  7. dt.ToLongDateString().ToString();//2005年11月5日
  8. dt.ToLongTimeString().ToString();//13:21:25
  9. dt.ToOADate().ToString();//38661.5565508218
  10. dt.ToShortDateString().ToString();//2005-11-5
  11. dt.ToShortTimeString().ToString();//13:21
  12. dt.ToUniversalTime().ToString();//2005-11-5 5:21:25
  13. dt.Year.ToString();//2005
  14. dt.Date.ToString();//2005-11-5 0:00:00
  15. dt.DayOfWeek.ToString();//Saturday
  16. dt.DayOfYear.ToString();//309
  17. dt.Hour.ToString();//13
  18. dt.Millisecond.ToString();//441
  19. dt.Minute.ToString();//30
  20. dt.Month.ToString();//11
  21. dt.Second.ToString();//28
  22. dt.Ticks.ToString();//632667942284412864
  23. dt.TimeOfDay.ToString();//13:30:28.4412864
  24. dt.ToString();//2005-11-5 13:47:04
  25. dt.AddYears1).ToString();//2006-11-5 13:47:04
  26. dt.AddDays1.1).ToString();//2005-11-6 16:11:04
  27. dt.AddHours1.1).ToString();//2005-11-5 14:53:04
  28. dt.AddMilliseconds1.1).ToString();//2005-11-5 13:47:04
  29. dt.AddMonths1).ToString();//2005-12-5 13:47:04
  30. dt.AddSeconds1.1).ToString();//2005-11-5 13:47:05
  31. dt.AddMinutes1.1).ToString();//2005-11-5 13:48:10
  32. dt.AddTicks1000).ToString();//2005-11-5 13:47:04
  33. dt.CompareTodt).ToString();//0
  34. dt.Add(?).ToString();//问号为一个时刻段
  35. dt.Equals"2005-11-6 16:11:04").ToString();//False
  36. dt.Equalsdt).ToString();//True
  37. dt.GetHashCode().ToString();//1474088234
  38. dt.GetType().ToString();//System.DateTime
  39. dt.GetTypeCode().ToString();//DateTime
  40.  
  41. dt.GetDateTimeFormats""s"")[0].ToString();//2005-11-05T14:06:25
  42. dt.GetDateTimeFormats""t"")[0].ToString();//14:06
  43. dt.GetDateTimeFormats""y"")[0].ToString();//2005年11月
  44. dt.GetDateTimeFormats""D"")[0].ToString();//2005年11月5日
  45. dt.GetDateTimeFormats""D"")[1].ToString();//2005 11 05
  46. dt.GetDateTimeFormats""D"")[2].ToString();//礼拜六 2005 11 05
  47. dt.GetDateTimeFormats""D"")[3].ToString();//礼拜六 2005年11月5日
  48. dt.GetDateTimeFormats""M"")[0].ToString();//11月5日
  49. dt.GetDateTimeFormats""f"")[0].ToString();//2005年11月5日 14:06
  50. dt.GetDateTimeFormats""g"")[0].ToString();//2005-11-5 14:06
  51. dt.GetDateTimeFormats""r"")[0].ToString();//Sat, 05 Nov 2005 14:06:25 GMT
  52.  
  53. string.Format"{0:d}"dt);//2005-11-5
  54. string.Format"{0:D}"dt);//2005年11月5日
  55. string.Format"{0:f}"dt);//2005年11月5日 14:23
  56. string.Format"{0:F}"dt);//2005年11月5日 14:23:23
  57. string.Format"{0:g}"dt);//2005-11-5 14:23
  58. string.Format"{0:G}"dt);//2005-11-5 14:23:23
  59. string.Format"{0:M}"dt);//11月5日
  60. string.Format"{0:R}"dt);//Sat, 05 Nov 2005 14:23:23 GMT
  61. string.Format"{0:s}"dt);//2005-11-05T14:23:23
  62. string.Format"{0:t}"dt);//14:23
  63. string.Format"{0:T}"dt);//14:23:23
  64. string.Format"{0:u}"dt);//2005-11-05 14:23:23Z
  65. string.Format"{0:U}"dt);//2005年11月5日 6:23:23
  66. string.Format"{0:Y}"dt);//2005年11月
  67. string.Format"{0}"dt);//2005-11-5 14:23:23
  68. string.Format"{0:yyyyMMddHHmmssffff}"dt);
  69.  
  70. 打算2个日期之间的天数差
  71. -----------------------------------------------
  72. DateTime dt1 = Convert.DateTime"2007-8-1");
  73. DateTime dt2 = Convert.DateTime"2007-8-15");
  74. TimeSpan span = dt2.Subtractdt1);
  75. int dayDiff = span.Days + 1;
  76.  
  77. 打算某年某月的天数
  78. -----------------------------------------------
  79. int days = DateTime.DaysInMonth2007 8);
  80. days = 31;
  81.  
  82. 给日期增进一天、削减一天
  83. -----------------------------------------------
  84. DateTime dt =DateTime.Now;
  85. dt.AddDays1); //增进一天
  86. dt.AddDays(-1);//削减一天
  87. 其它年份方法近似...
  88.  
  89. Oracle SQL里转换日期函数
  90. -----------------------------------------------
  91. to_date"2007-6-6"""YYYY-MM-DD");
  92. to_date("2007/6/6",""yyyy/mm/dd");
  93.  
  94. 如下一组数据,若何查找内外包含9月份的记实:
  95. CGGC_STRATDATE CGGC_ENDDATE
  96. =========================================
  97. 2007-8-4 2007-9-5
  98. 2007-9-5 2007-9-20
  99. 2007-9-22 2007-10-5
  100.  
  101. SELECT * FROM TABLE
  102. TO_DATE""2007/9/1""""yyyy/mm/dd"" BETWEEN CGGC_STRATDATE
  103. AND CGGC_ENDDATE OR CGGC_STRATDATE >=TO_DATE""2007/9/1""""yyyy/mm/dd""
  104. AND CGGC_ENDDATE<=TO_DATE""2007/9/30""""yyyy/mm/dd"" "
  105. OR TO_DATE(""2007/9/30"",""yyyy/mm/dd"") BETWEEN CGGC_STRATDATE
  106. AND CGGC_ENDDATE) ORDER BY CGGC_STRATDATE ASC

  

ow.AddMonths(3 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01");
DateTime.Parse(DateTime.Now.AddMonths(6  - ((DateTime.Now.Month - 1) %  3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();
//上季度
DateTime.Now.AddMonths(-3 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01");
DateTime.Parse(DateTime.Now.AddMonths(0  - ((DateTime.Now.Month - 1) %  3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();

C#中的DateTime:本周第一天,本月第一天,今年第一天,本周第一天的时间的更多相关文章

  1. 在oracle里,如何取得本周、本月、本季度、本年度的第一天和最后一天的时间

    在oracle里,如何取得本周.本月.本季度.本年度的第一天和最后一天的时间 --本周 select trunc(sysdate,'d')+1 from dual; select trunc(sysd ...

  2. mysql 获取季度的第一天 本月的第一天,本周的第一天sql语句(转)

    感谢:http://www.111cn.net/database/110/d45124323da8d2d87b80f78319987eda.htm 查看同主题的另一篇博客:http://blog.cs ...

  3. Oracle 获取本周、本月、本季、本年的第一天和最后一天

    Oracle 获取本周.本月.本季.本年的第一天和最后一天 --本周 select trunc(sysdate, 'd') + 1 from dual; select trunc(sysdate, ' ...

  4. c# 获取 本周、本月、本季度、本年 的开始时间或结束时间

    #region 获取 本周.本月.本季度.本年 的开始时间或结束时间 /// <summary> /// 获取结束时间 /// </summary> /// <param ...

  5. Dynamics AX 2012 R2 在AIF服务契约中使用DateTime

    Reinhard在AIF中使用DateTime作为服务契约的参数,与DotNet程序进行交互时,总是因为时区的问题,导致DotNet提交的System.DateTime与AIF中接收的DateTime ...

  6. sql语句中获取datetime的日期部分或时间部分

    sql语句中获取datetime的日期部分 sql语句中 经常操作操作datetime类型数据.今天在写一个存储过程的时候需要将 一个datetime的值的 日期部分提取出来.网上有许多这方面的介绍. ...

  7. MySQL中的datetime与timestamp比较-------转载

    原文地址http://database.51cto.com/art/200905/124240.htm MySQL中的datetime与timestamp比较 本文将通过实例比较MySQL中的date ...

  8. sql语句中获取datetime任何部分

    sql语句中获取datetime的日期部分 sql语句中 经常操作操作datetime类型数据.今天在写一个存储过程的时候需要将 一个datetime的值的 日期部分提取出来.网上有许多这方面的介绍. ...

  9. SQL server数据库中的DateTime类型出现的问题

    我们知道这个SQL server数据库中的DateTime类型是数据库应用开发中经经常使用到的一种数据类型.而C#语言中也有DateTime类型,尽管二者都是用来描写叙述时间的,可是它们的默认值是不同 ...

  10. SQL-27 给出每个员工每年薪水涨幅超过5000的员工编号emp_no、薪水变更开始日期from_date以及薪水涨幅值salary_growth,并按照salary_growth逆序排列。 提示:在sqlite中获取datetime时间对应的年份函数为strftime('%Y', to_date)

    题目描述 给出每个员工每年薪水涨幅超过5000的员工编号emp_no.薪水变更开始日期from_date以及薪水涨幅值salary_growth,并按照salary_growth逆序排列. 提示:在s ...

随机推荐

  1. ios之点语法

    第一个object c 程序 首先新建一个项目,“create a new Xcode project"-"OS X下的Application"-"Comman ...

  2. IoC模式(Inversion of Control)

      1.依赖 依赖就是有联系,有地方使用到它就是有依赖它,一个系统不可能完全避免依赖.如果你的一个类或者模块在项目中没有用到它,恭喜你,可以从项目中剔除它或者排除它了,因为没有一个地方会依赖它.下面看 ...

  3. Delphi Form显示在第二个显示器中的方法

    Delphi 中窗体Form显示在第二个显示器中的方法: 假定要显示在扩展的第二个显示器的Form的名称为frmFloat,则除了要设置该form的top.left.width.height为Scre ...

  4. 使用DataSet Datatable 更新数据库的三种方式

    1:自动生成命令的条件 CommandBuilder 方法a)动态指定 SelectCommand 属性b)利用 CommandBuilder 对象自动生成 DataAdapter 的 DeleteC ...

  5. c# winform 把彩色图片转换为灰色的图片,变灰,灰度图片,速度很快,safe,unsafe

    把彩色图片转换为灰色的图片,直接用.net接口遍历每个像素点转换的效率非常低,800K的图片65万像素我的电脑要用5分钟,而用了unsafe,速度提高了几千倍,同样的图片只用了0.几秒 附一个常用的遍 ...

  6. C++ CheckBox_Porerty

    主题 1. s       Caption属性 CheckBox   CheckDlgButton BOOL CheckDlgButton(      HWND hDlg,      // handl ...

  7. poj 3613 Cow Relays

    Cow Relays Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5411   Accepted: 2153 Descri ...

  8. [Javascript] Either Functor

    Either Functor: // API Right(val) // resolve the value Left(val) // return error message Examples: m ...

  9. [MODX] 1. Template *

    After uploading javascript, css and images to the assets folder. We try to use Template to customize ...

  10. Android 进阶学习:事件分发机制全然解析,带你从源代码的角度彻底理解(上)

    http://blog.csdn.net/guolin_blog/article/details/9097463 事实上我一直准备写一篇关于Android事件分发机制的文章,从我的第一篇博客開始,就零 ...