7

我目前正在用 ASP.Net C# 编写一个小日历。目前为了生成一周的行,我执行以下 for 循环:

var iWeeks = 6;
for (int w = 0; w < iWeeks; w++) {

这很好用,但是,有些月只有 5 周,在极少数情况下,有 4 周。

如何计算特定月份所需的行数?

这是我正在创建的示例:

在此处输入图像描述

但是,正如您在上个月看到的那样,只需要 5 行。以本月(2008 年 8 月)为例,该月从星期六开始,在第 6 周/第 6 行的星期一结束。

在谷歌上找到的图片


这是我正在创建的示例:

在此处输入图像描述

但是,正如您在上个月看到的那样,只需要 5 行。以本月(2008 年 8 月)为例,该月从星期六开始,在第 6 周/第 6 行的星期一结束。

在谷歌上找到的图片

4

9 回答 9

6

这是执行此操作的方法:

public int GetWeekRows(int year, int month)
{
    DateTime firstDayOfMonth = new DateTime(year, month, 1);
    DateTime lastDayOfMonth = new DateTime(year, month, 1).AddMonths(1).AddDays(-1);
    System.Globalization.Calendar calendar = System.Threading.Thread.CurrentThread.CurrentCulture.Calendar;
    int lastWeek = calendar.GetWeekOfYear(lastDayOfMonth, System.Globalization.CalendarWeekRule.FirstFourDayWeek, DayOfWeek.Monday);
    int firstWeek = calendar.GetWeekOfYear(firstDayOfMonth, System.Globalization.CalendarWeekRule.FirstFourDayWeek, DayOfWeek.Monday);
    return lastWeek - firstWeek + 1;
}

您可以通过修改 System.Globalization.CalendarWeekRule.FirstFourDayWeek 部分来自定义日历周规则。我希望代码是不言自明的。

于 2008-08-13T14:03:39.223 回答
2

好吧,这取决于您使用的文化,但假设您可以使用 Thread.CurrentThread.CurrentCulture,那么获取今天星期的代码将是:

Culture culture = Thread.CurrentThread.CurrentCulture;
Calendar cal = culture.Calendar;
Int32 week = cal.GetWeekOfYear(DateTime.Today,
    culture.DateTimeFormat.CalendarWeekRule,
    culture.DateTimeFormat.FirstDayOfWeek);
于 2008-08-13T13:46:30.317 回答
0

如何检查第一天和最后一天将在哪一周?

于 2008-08-13T13:39:47.850 回答
0

儒略历/公历中的月份每年都有相同的天数,除了 2 月,根据年份的闰年可以有 28 天或 29 天。您可以在http://en.wikipedia.org/wiki/Gregorian_calendar的描述部分找到天数。

正如@darkdog 提到的,你有 DateTime.DaysInMonth。只需这样做:

var days = DateTime.DaysInMonth(year, month) + 
           WhatDayOfWeekTheMonthStarts(year, month);    
int rows = (days / 7);  
if (0 < days % 7)  
{  
    ++rows;
}  

考虑到出于全球化/本地化目的,世界某些地区使用不同的日历/年度组织方法。

于 2008-08-13T13:43:42.023 回答
0

试试这个,

DateTime.DaysInMonth
于 2008-08-13T13:45:22.613 回答
0

检查Calendar.GetWeekOfYear。它应该可以解决问题。

它有一个问题,它不遵循 ISO 8601 的 4 天规则,但除此之外它很整洁。

于 2008-08-13T13:46:46.480 回答
0

您可以使用 DateTime.DaysInMonth(int WhichYear,int WhichMonth);

于 2008-08-13T13:47:42.297 回答
0

问题不在于该月的天数,而在于它跨越了多少周。

非闰年的 2 月将有 28 天,如果该月的第一天是星期一,则 2 月将恰好跨越 4 周数字。

但是,如果该月的第一天是星期二或一周中的任何其他日期,则 2 月将跨越 5 个周数。

一个 31 天的月份可以以同样的方式跨越 5 或 6 周。如果该月从星期一开始,则 31 天为您提供 5 个周数。如果月份从星期六或星期日开始,它将跨越 6 周数。

所以获取这个数字的正确方法是找到该月的第一天和最后一天的周数。


编辑#1:这是计算给定月份跨度的周数的方法: 编辑#2:修复了代码中的错误

public static Int32 GetWeekForDateCurrentCulture(DateTime dt)
{
    CultureInfo culture = Thread.CurrentThread.CurrentCulture;
    Calendar cal = culture.Calendar;
    return cal.GetWeekOfYear(dt,
        culture.DateTimeFormat.CalendarWeekRule,
        culture.DateTimeFormat.FirstDayOfWeek);
}

public static Int32 GetWeekSpanCountForMonth(DateTime dt)
{
    DateTime firstDayInMonth = new DateTime(dt.Year, dt.Month, 1);
    DateTime lastDayInMonth = firstDayInMonth.AddMonths(1).AddDays(-1);
    return
        GetWeekForDateCurrentCulture(lastDayInMonth)
        - GetWeekForDateCurrentCulture(firstDayInMonth)
        + 1;
}
于 2008-08-13T13:49:48.300 回答
0

首先找出该月的第一天在哪个工作日。只需使用第一天新建一个日期时间,始终为 1,以及相关的年份和月份,它上面有一个星期几属性。

然后从这里,您可以使用该月的天数,DateTime.DaysInMonth来确定除以 7 的周数,然后将第一天从 1 开始的天数相加。例如,

public static int RowsForMonth(int month, int year)
{
    DateTime first = new DateTime(year, month, 1);

    //number of days pushed beyond monday this one sits
    int offset = ((int)first.DayOfWeek) - 1;

    int actualdays = DateTime.DaysInMonth(month, year) +  offset;

    decimal rows = (actualdays / 7);
    if ((rows - ((int)rows)) > .1)
    {
        rows++;
    }
    return rows;
}
于 2008-08-13T13:57:34.930 回答