//DateTime里只有DayOfWeek这个属性,不能直接得到当天是当月的第几周。所以写了个函数,来计算一个日期是当月的第几个星期,代码有详细的注释,就不多说了
//参数说明:dtSel:要判断的日期,sundayStart:一周的第一天是否为周日
/// <summary>
/// 判断给定日期是本月内的第几周
/// </summary>
/// <param name="dateTime">给定日期(DateTime)对象</param>
/// <param name="sundayStart">默认为true:一周的第一天为周日,false:一周的第一天为周一</param>
/// <returns>返回给定日期是本月内的第几周</returns>
public static int WeekOfMonth(DateTime dtSel, bool sundayStart=true)
{
//如果要判断的日期为1号,则肯定是第一周了
if (dtSel.Day == 1)
return 1;
else
{
//得到本月第一天
DateTime dtStart = new DateTime(dtSel.Year, dtSel.Month, 1);
//得到本月第一天是周几
int dayofweek = (int)dtStart.DayOfWeek;
//如果不是以周日开始,需要重新计算一下dayofweek,详细风DayOfWeek枚举的定义
if (!sundayStart)
{
dayofweek -= 1;
if (dayofweek < 0)
dayofweek = 7;
}
//得到本月的第一周一共有几天
int startWeekDays = 7 - dayofweek;
//如果要判断的日期在第一周范围内,返回1
if (dtSel.Day <= startWeekDays)
return 1;
else
{
int aday = dtSel.Day + 7 - startWeekDays;
return aday / 7 + (aday % 7 > 0 ? 1 : 0);
}
}
}