需要帮助如何获得当月的第一个日期和一周的最后日期。
到目前为止,我已经做了以下事情,但在某些情况下仍然会下降,特别是在开始日期和结束日期是星期天的情况下:
var givenDate = new DateTime(2018,4,1);
var intervalToStart = givenDate.DayOfWeek - DayOfWeek.Monday;
var startDate = givenDate.AddDays(-intervalToStart);
DateTime endDate;
int intervalToEnd = 0;
if (startDate.Month != givenDate.Month)
startDate = new DateTime(givenDate.Year, givenDate.Month, 1);
var dayOfWeekStartDate = startDate.DayOfWeek.ToString().ToLower();
switch (dayOfWeekStartDate)
{
case "sunday": intervalToEnd = 0;
break;
case "monday": intervalToEnd = 6;
break;
case "tuesday": intervalToEnd = 5;
break;
case "wednesday": intervalToEnd = 4;
break;
case "thursday": intervalToEnd = 3;
break;
case "friday": intervalToEnd = 2;
break;
case "saturday": intervalToEnd = 1;
break;
}
endDate = startDate.AddDays(intervalToEnd);
Console.WriteLine(startDate);
Console.WriteLine(endDate);
案例1:
截止日期:2018年5月5日(周六)
第一个星期:2018年5月1日(星期二)
上周日期:208年5月6日(星期日)
案例2:
截止日期:2018年5月9日(周三)
第一个星期:2018年5月7日(星期一)
上周日期:2018年5月13日(星期日)
案例3:
截止日期:2018年4月1日(星期日)
第一个星期:2018年4月1日(星期日)
上周日期:2018年4月1日(星期日)
案例4:
截止日期:2018年6月2日(周六)
第一个星期:2018年6月1日(星期五)
上周日期:2018年6月3日(星期日)
高度赞赏概念或答案。
提前谢谢。
答案 0 :(得分:4)
如果星期一会进入上个月,您想要返回该月的第一天吗?
public static Tuple<DateTime, DateTime> GetFirstAndLastWeekDate(DateTime dt, DayOfWeek firstDayOfWeek = DayOfWeek.Monday)
{
int diff = (7 + (dt.DayOfWeek - firstDayOfWeek)) % 7;
DateTime firstDay = dt.AddDays(-1 * diff).Date;
DateTime lastDay = firstDay.AddDays(6);
if (dt.Month != firstDay.Month)
{
firstDay = new DateTime(dt.Year, dt.Month, 1);
}
return Tuple.Create(firstDay, lastDay);
}
答案 1 :(得分:0)
,代码就像这样
var givenDate = new DateTime(2018, 4, 1);
int addMax = DateTime.DaysInMonth(givenDate.Year, givenDate.Month) - givenDate.Day;
int add = Math.Min(addMax, ((DayOfWeek.Saturday - givenDate.DayOfWeek) + 1) % 7);
int subMax = givenDate.Day - 1;
int sub = Math.Min(subMax, (givenDate.DayOfWeek - DayOfWeek.Monday + 7) % 7);
var firstDate = givenDate.AddDays(-sub);
var lastDate = givenDate.AddDays(add);
Console.Write("Give: {0}({1})\nFirst: {2}({3})\nLast: {4}({5})",
givenDate, givenDate.DayOfWeek,
firstDate, firstDate.DayOfWeek,
lastDate, lastDate.DayOfWeek);