我想要得到给定日期所在月份的第一天和最后一天。日期来自UI字段中的值。

如果我使用时间选择器,我可以说

var maxDay = dtpAttendance.MaxDate.Day;

但我试图从DateTime对象中获取它。如果我有这个。

DateTime dt = DateTime.today;

如何从dt中获取每月的第一天和最后一天?


当前回答

你可以试着得到本月的第一天;

DateTime.Now.AddDays(-(DateTime.Now.Day-1))

给它赋一个值。

是这样的:

dateEndEdit.EditValue = DateTime.Now;
dateStartEdit.EditValue = DateTime.Now.AddDays(-(DateTime.Now.Day-1));

其他回答

对于波斯文化来说

PersianCalendar pc = new PersianCalendar();            

var today = pc.GetDayOfMonth(DateTime.Now);
var firstDayOfMonth = pc.GetDayOfMonth(DateTime.Now.AddDays(-(today-1)));
var lastDayOfMonth = pc.GetDayOfMonth(DateTime.Now.AddMonths(1).AddDays(-today));            
Console.WriteLine("First day "+ firstDayOfMonth);
Console.WriteLine("Last day " + lastDayOfMonth);

很简单

Begin = new DateTime(DateTime.Now.Year, DateTime.Now.Month,1).ToShortDateString();
End = new DataFim.Text = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.DaysInMonth(DateTime.Now.Year, DateTime.Now.Month)).ToShortDateString();

“一个月的最后一天”实际上是“下个月的第一天,减1”。所以这是我使用的,不需要“DaysInMonth”方法:

public static DateTime FirstDayOfMonth(this DateTime value)
{
    return new DateTime(value.Year, value.Month, 1);
}

public static DateTime LastDayOfMonth(this DateTime value)
{
    return value.FirstDayOfMonth()
        .AddMonths(1)
        .AddMinutes(-1);
}

注意: 我在这里使用AddMinutes(-1)而不是AddDays(-1)的原因是,通常你需要这些日期函数来报告一些日期-期间,当你构建一个期间的报告时,“结束日期”实际上应该是类似于2015年10月31日23:59:59这样的东西,这样你的报告就可以正确地工作-包括当月最后一天的所有数据。

也就是说,你实际上是在“这个月的最后一刻”。不是最后一天。

好了,我要闭嘴了。

你可以试着得到本月的第一天;

DateTime.Now.AddDays(-(DateTime.Now.Day-1))

给它赋一个值。

是这样的:

dateEndEdit.EditValue = DateTime.Now;
dateStartEdit.EditValue = DateTime.Now.AddDays(-(DateTime.Now.Day-1));

创建一个DateTime类的实例

DateTime dateTime = DateTime.Now;

如果你想要得到这个月的最后一天,你可以这样做

int lastDayOfMonth = DateTime.DaysInMonth(caducidadPuntos.Year, caducidadPuntos.Month);

如果你想得到每月的第一天,你可以这样做

DateTime firstDayMonth = new DateTime(dateTime.Year, dateTime.Month, 1);