在c#中获取上个月的第一天和最后一天的日期

时间:2009-02-26 18:11:47

标签: c# .net datetime date

我想不出一个简单的一两个班轮可以在前几个月的第一天和最后一天得到。

我是LINQ-ifying一个调查网络应用程序,他们挤压了一个新的要求。

调查必须包含上个月的所有服务请求。因此,如果是4月15日,我需要所有Marches请求ID。

var RequestIds = (from r in rdc.request 
                  where r.dteCreated >= LastMonthsFirstDate && 
                  r.dteCreated <= LastMonthsLastDate 
                  select r.intRequestId);

如果没有开关,我就无法轻易想到日期。除非我是盲目的,并且忽视了内部方法。

10 个答案:

答案 0 :(得分:277)

var today = DateTime.Today;
var month = new DateTime(today.Year, today.Month, 1);       
var first = month.AddMonths(-1);
var last = month.AddDays(-1);

如果你真的需要一两行,就行了。

答案 1 :(得分:21)

我过去这样做的方式是第一次到达本月的第一天

dFirstDayOfThisMonth = DateTime.Today.AddDays( - ( DateTime.Today.Day - 1 ) );

然后减去一天到上个月结束

dLastDayOfLastMonth = dFirstDayOfThisMonth.AddDays (-1);

然后减去一个月以获得上个月的第一天

dFirstDayOfLastMonth = dFirstDayOfThisMonth.AddMonths(-1);

答案 2 :(得分:11)

使用Fluent DateTime https://github.com/FluentDateTime/FluentDateTime

        var lastMonth = 1.Months().Ago().Date;
        var firstDayOfMonth = lastMonth.FirstDayOfMonth();
        var lastDayOfMonth = lastMonth.LastDayOfMonth();

答案 3 :(得分:8)

DateTime LastMonthLastDate = DateTime.Today.AddDays(0 - DateTime.Today.Day);
DateTime LastMonthFirstDate = LastMonthLastDate.AddDays(1 - LastMonthLastDate.Day);

答案 4 :(得分:5)

我使用这个简单的单行:

public static DateTime GetLastDayOfPreviousMonth(this DateTime date)
{
    return date.AddDays(-date.Day);
}

请注意,它会保留时间。

答案 5 :(得分:4)

使用扩展方法的方法:

class Program
{
    static void Main(string[] args)
    {
        DateTime t = DateTime.Now;

        DateTime p = t.PreviousMonthFirstDay();
        Console.WriteLine( p.ToShortDateString() );

        p = t.PreviousMonthLastDay();
        Console.WriteLine( p.ToShortDateString() );


        Console.ReadKey();
    }
}


public static class Helpers
{
    public static DateTime PreviousMonthFirstDay( this DateTime currentDate )
    {
        DateTime d = currentDate.PreviousMonthLastDay();

        return new DateTime( d.Year, d.Month, 1 );
    }

    public static DateTime PreviousMonthLastDay( this DateTime currentDate )
    {
        return new DateTime( currentDate.Year, currentDate.Month, 1 ).AddDays( -1 );
    }
}

查看此链接 http://www.codeplex.com/fluentdatetime 对于一些灵感的DateTime扩展。

答案 6 :(得分:3)

电子商务中的规范用例是信用卡到期日,MM / yy。减去一秒而不是一天。否则,该卡将在到期月的整个最后一天过期。

DateTime expiration = DateTime.Parse("07/2013");
DateTime endOfTheMonthExpiration = new DateTime(
  expiration.Year, expiration.Month, 1).AddMonths(1).AddSeconds(-1);

答案 7 :(得分:1)

DateTime now = DateTime.Now;
int prevMonth = now.AddMonths(-1).Month;
int year = now.AddMonths(-1).Year;
int daysInPrevMonth = DateTime.DaysInMonth(year, prevMonth);
DateTime firstDayPrevMonth = new DateTime(year, prevMonth, 1);
DateTime lastDayPrevMonth = new DateTime(year, prevMonth, daysInPrevMonth);
Console.WriteLine("{0} {1}", firstDayPrevMonth.ToShortDateString(),
  lastDayPrevMonth.ToShortDateString());

答案 8 :(得分:1)

如果您的日期时间不是严格的日历日期,您应该考虑使用enddate排除比较... 这样可以防止您遗漏在1月31日期间创建的任何请求。

DateTime now = DateTime.Now;
DateTime thisMonth = new DateTime(now.Year, now.Month, 1);
DateTime lastMonth = thisMonth.AddMonths(-1);

var RequestIds = rdc.request
  .Where(r => lastMonth <= r.dteCreated)
  .Where(r => r.dteCreated < thisMonth)
  .Select(r => r.intRequestId);

答案 9 :(得分:1)

这是Mike W的回答:

internal static DateTime GetPreviousMonth(bool returnLastDayOfMonth)
{
    DateTime firstDayOfThisMonth = DateTime.Today.AddDays( - ( DateTime.Today.Day - 1 ) );
    DateTime lastDayOfLastMonth = firstDayOfThisMonth.AddDays (-1);
    if (returnLastDayOfMonth) return lastDayOfLastMonth;
    return firstDayOfThisMonth.AddMonths(-1);
}

您可以这样称呼它:

dateTimePickerFrom.Value = GetPreviousMonth(false);
dateTimePickerTo.Value = GetPreviousMonth(true);