1. //DateTime里只有DayOfWeek这个属性,不能直接得到当天是当月的第几周。所以写了个函数,来计算一个日期是当月的第几个星期,代码有详细的注释,就不多说了
    2. //参数说明:dtSel:要判断的日期,sundayStart:一周的第一天是否为周日
    3. /// <summary>
    4. /// 判断给定日期是本月内的第几周
    5. /// </summary>
    6. /// <param name="dateTime">给定日期(DateTime)对象</param>
    7. /// <param name="sundayStart">默认为true:一周的第一天为周日,false:一周的第一天为周一</param>
    8. /// <returns>返回给定日期是本月内的第几周</returns>
    9. public static int WeekOfMonth(DateTime dtSel, bool sundayStart=true)
    10. {
    11. //如果要判断的日期为1号,则肯定是第一周了
    12. if (dtSel.Day == 1)
    13. return 1;
    14. else
    15. {
    16. //得到本月第一天
    17. DateTime dtStart = new DateTime(dtSel.Year, dtSel.Month, 1);
    18. //得到本月第一天是周几
    19. int dayofweek = (int)dtStart.DayOfWeek;
    20. //如果不是以周日开始,需要重新计算一下dayofweek,详细风DayOfWeek枚举的定义
    21. if (!sundayStart)
    22. {
    23. dayofweek -= 1;
    24. if (dayofweek < 0)
    25. dayofweek = 7;
    26. }
    27. //得到本月的第一周一共有几天
    28. int startWeekDays = 7 - dayofweek;
    29. //如果要判断的日期在第一周范围内,返回1
    30. if (dtSel.Day <= startWeekDays)
    31. return 1;
    32. else
    33. {
    34. int aday = dtSel.Day + 7 - startWeekDays;
    35. return aday / 7 + (aday % 7 > 0 ? 1 : 0);
    36. }
    37. }
    38. }