C# 如何获取一个月中的 "greyed" 天 DateTime
C# How to get the "greyed" days of a month DateTime
在 Windows 10 日历中,例如,我们发现一个 7x6 天的网格代表一个月中的每一天,但很明显没有一个月有 42 天,所以“溢出”天数,通过无论如何,在网格中显示但不是当前月份的日子会显示为另一个月份的一天。有没有一些简单的方法可以在 C# 上使用 DateTime class?
例如,在 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 class 的扩展方法,它 returns 自定义 class 即 returns 月份前后的日期, class实现如下:
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
属性。它 returns 一个对应于周日到周六的 DayOfWeek
枚举值,可以相应地转换为范围从 0 到 6 的 int
。
以你的月份为准,构造一个 DateTime
对应于该月 1 号的对象。现在将它的 DayOfWeek
转换为 int
,现在您在日历顶部有灰色天数。从月底获取数字同样简单。为该月的最后一天构建一个 DateTime
对象并将其 DayOfWeek
转换为 int
并从 6 中减去得到灰色天数。
如果您需要为那些灰色日子确定日期,请从该月的第一天开始减去 24 小时以获得上个月的最后一天。日历结束的灰色天数可以假定为从 1 开始。
使用 DateTime 和 DateTimeOffset 结构,您可以使用 Day of week 函数计算月份日期类型的第一天。这将 return 一个枚举。如果您将枚举转换为 int(注意,0 = 星期日,它确实与 windows 日历相关),您将能够循环返回以获取这些日期。我建议使用 List 来存储这些日期,但我不知道你现在的情况:)
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));
}
注意,要获取daysinmonth,需要使用DateTime.DaysInMonth()函数,要获取Last day,只需在第一天加上1个月,然后减去一天。
在 Windows 10 日历中,例如,我们发现一个 7x6 天的网格代表一个月中的每一天,但很明显没有一个月有 42 天,所以“溢出”天数,通过无论如何,在网格中显示但不是当前月份的日子会显示为另一个月份的一天。有没有一些简单的方法可以在 C# 上使用 DateTime class?
例如,在 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 class 的扩展方法,它 returns 自定义 class 即 returns 月份前后的日期, class实现如下:
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
属性。它 returns 一个对应于周日到周六的 DayOfWeek
枚举值,可以相应地转换为范围从 0 到 6 的 int
。
以你的月份为准,构造一个 DateTime
对应于该月 1 号的对象。现在将它的 DayOfWeek
转换为 int
,现在您在日历顶部有灰色天数。从月底获取数字同样简单。为该月的最后一天构建一个 DateTime
对象并将其 DayOfWeek
转换为 int
并从 6 中减去得到灰色天数。
如果您需要为那些灰色日子确定日期,请从该月的第一天开始减去 24 小时以获得上个月的最后一天。日历结束的灰色天数可以假定为从 1 开始。
使用 DateTime 和 DateTimeOffset 结构,您可以使用 Day of week 函数计算月份日期类型的第一天。这将 return 一个枚举。如果您将枚举转换为 int(注意,0 = 星期日,它确实与 windows 日历相关),您将能够循环返回以获取这些日期。我建议使用 List 来存储这些日期,但我不知道你现在的情况:)
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));
}
注意,要获取daysinmonth,需要使用DateTime.DaysInMonth()函数,要获取Last day,只需在第一天加上1个月,然后减去一天。