C#如何获取一个月的“灰色”日期Date

问题描述

以Windows 10日历为例,我们发现一个7x6天的网格代表一个月的每一天,但是很明显,没有一个月有42天,因此无论如何,“溢出”的天在表格中显示,但不是当前月份显示为另一个月的某天。是否有一些简单的方法可以通过DateTime类在C#上使用这些天?

例如,在2020/08年度,“灰色天数”是:26、27、28、29、30、31(上个月的天数)和1、2、3、4、5(下个月)。

In case that isn't clear,this is a screenshot showing the days that i'm referring

我找不到与我的问题有关的任何问题。

编辑:

最好的答案是@ChilliPenguin,这是我的实现方式

public static MonthGrayDays GrayDays(this DateTime time) {
        List<DateTime> before = new List<DateTime>();
        List<DateTime> after = new List<DateTime>();

        DateTime firstDay = new DateTime(time.Year,time.Month,1);
        DateTime prevMonth = firstDay.AddDays(-1);
        DateTime nextMonth = firstDay.AddMonths(1);
        int daysInMonth = DateTime.DaysInMonth(time.Year,time.Month);

        for (int a = 0; a < (int)firstDay.DayOfWeek; a++)
        {
            before.Add(prevMonth.AddDays(-a));
        }

        before.Reverse();

        int count = before.Count();

        for (int b = 0; b < 42 - count - daysInMonth; b++)
        {
            after.Add(nextMonth.AddDays(b));
        }

        return new MonthGrayDays {prevIoUsMonth = before,nextMonth = after};
    }

这是DateTime类的扩展方法,它返回一个自定义类,该类返回月之前和之后的日期,该类的实现如下:

public class MonthGrayDays {
    public List<DateTime> prevIoUsMonth;
    public List<DateTime> nextMonth;
}

要使用扩展方法,只需调用

DateTime Now = new DateTime(2020,8,1);
foreach (DateTime date in Now.GrayDays().prevIoUsMonth) {
    Console.WriteLine(date.Day);
}
Console.WriteLine("/");
foreach (DateTime date in Now.GrayDays().nextMonth) {
   Console.WriteLine(date.Day);
}

解决方法

我认为没有自动解决方案,但是逻辑很简单,可以逐步解决。最重要的是DateTime.DayOfWeek属性。它返回一个对应于星期日至星期六的DayOfWeek枚举值,该值可以转换为一个介于0到6之间的int

以您的月份为基础,并构造一个与该月的1号相对应的DateTime对象。现在,将其DayOfWeek转换为int,现在日历顶部的灰色天数已到。从月底开始获取数字同样简单。为该月的最后一天构建一个DateTime对象,并将其DayOfWeek转换为int并减去6以得到灰色天数。

如果您需要为那些灰色的日子约会,请从该月的第一天开始,然后减去24小时以获得上个月的最后一天。日历结尾的灰色日子可以假定从1开始。

,

使用DateTime和DateTimeOffset结构,您可以使用Day of week函数来计算当月类型的第一天。这将返回一个枚举。如果将枚举转换为int(注意,0 =星期日,与Windows日历相关),则可以循环返回这些日期。我建议使用列表来存储这些日期,但我不知道您的当前情况:)

for (int a = 0; a < (int)FirstDay.DayOfWeek; a++)
        {
            graydays.Add(prevmonth.AddDays(-a));
        }

要获取当前月份之后的日期,我们可以获取列出的天数,该月中的天数以及网格区域(在这种情况下为42)来计算该月之后的天数需要考虑。

int count = graydays.Count();

    for (int b = 0; b < 42 - count - daysinmonth; b++)
    {
        graydays.Add(LastDayOfMonth.AddDays(b));
    }

注意,要获取dayinmonth,您需要使用DateTime.DaysInMonth()函数,并获取Last Day,只需在第一天加上1个月,然后减去一天即可。