根据当前时间计算本周第一天的日期以及本月第一天的日期

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了根据当前时间计算本周第一天的日期以及本月第一天的日期相关的知识,希望对你有一定的参考价值。

/// <summary>
  /// 计算本周起始日期(礼拜一的日期)
  /// </summary>
  /// <param name="someDate">该周中任意一天</param>
  /// <returns>返回礼拜一日期,后面的具体时、分、秒和传入值相等</returns>
  public static DateTime CalculateFirstDateOfWeek(DateTime someDate)
  {
   int i = someDate.DayOfWeek - DayOfWeek.Monday;
   if (i == -1) i = 6;// i值 > = 0 ,因为枚举原因,Sunday排在最前,此时Sunday-Monday=-1,必须+7=6。
   TimeSpan ts = new TimeSpan(i, 0, 0, 0);
   return someDate.Subtract(ts);
  }

//调用当周第一天

DateTime nowMon = CalculateFirstDateOfWeek(DateTime.Now);
DateTime nowMonday = new DateTime(nowMon.Year, nowMon.Month, nowMon.Day);

//当月第一天
DateTime now = DateTime.Now;
DateTime nowJanuary = new DateTime(now.Year, now.Month, 1);

 

/**//// <summary>
  /// 计算本周结束日期(礼拜日的日期)
  /// </summary>
  /// <param name="someDate">该周中任意一天</param>
  /// <returns>返回礼拜日日期,后面的具体时、分、秒和传入值相等</returns>
  public static DateTime CalculateLastDateOfWeek(DateTime someDate)
  {
   int i = someDate.DayOfWeek - DayOfWeek.Sunday;
   if(i != 0) i = 7 - i;// 因为枚举原因,Sunday排在最前,相减间隔要被7减。
   TimeSpan ts = new TimeSpan(i, 0, 0, 0);
   return someDate.Add(ts);
  }

以上是关于根据当前时间计算本周第一天的日期以及本月第一天的日期的主要内容,如果未能解决你的问题,请参考以下文章

EXCEL问题,怎么用函数或公式取得当月最后一天

SQL Count 天数到本月的第一天

PHP获取本月第一天和上个月第一天的日期

Java获取本月最后一天问题

sqlserver如何根据当前日期获得上月某一天的日期

SQL语句 如何取得指定月份的最后一天的日期