我发现这个问题已经在Java、JavaScript和PHP中得到了解答,但c#中没有。那么,如何在c#中计算两个日期之间的天数呢?


当前回答

首先声明一个稍后会返回的类:

public void date()
{
    Datetime startdate;
    Datetime enddate;
    Timespan remaindate;

    startdate = DateTime.Parse(txtstartdate.Text).Date;
    enddate = DateTime.Parse(txtenddate.Text).Date;

    remaindate = enddate - startdate;

    if (remaindate != null)
    {
        lblmsg.Text = "you have left with " + remaindate.TotalDays + "days.";
    }
    else
    {
        lblmsg.Text = "correct your code again.";
    }
}

protected void btncal_Click(object sender, EventArgs e)
{
    date();
}

使用按钮控件调用上面的类。这里有一个例子:

其他回答

使用时间跨度可以解决问题,因为它有很多属性:

DateTime strt_date = DateTime.Now;
DateTime end_date = Convert.ToDateTime("10/1/2017 23:59:59");
//DateTime add_days = end_date.AddDays(1);
TimeSpan nod = (end_date - strt_date);
Console.WriteLine(strt_date + "" + end_date + "" + "" + nod.TotalHours + "");
Console.ReadKey();
DateTime xmas = new DateTime(2009, 12, 25);
double daysUntilChristmas = xmas.Subtract(DateTime.Today).TotalDays;

我认为这会达到你的目的:

DateTime d1 = DateTime.Now;
DateTime d2 = DateTime.Now.AddDays(-1);

TimeSpan t = d1 - d2;
double NrOfDays = t.TotalDays;

在计算两个日期之间的天数时,经常会有关于时间(小时)的争论。对这个问题的回答和他们的评论都没有例外。

考虑到StartDate和EndDate是DateTime类型:如果性能不是问题,我强烈建议通过中间转换记录您的计算。例如,(EndDate - StartDate)。天是不直观的,因为舍入将依赖于StartDate和EndDate的小时组件。

如果您希望以天为单位的持续时间包括天的分数,那么如前所述 使用(结束日期-开始日期). totaldays。 如果你想要反映持续时间 两天之间的距离,然后使用(EndDate。日期-开始日期。日期).天 如果你想让持续时间反映 开始日期的上午和开始日期的晚上之间的持续时间 结束日期(通常在项目管理软件中看到),然后使用 (EndDate。日期-开始日期。日期)。天+ 1

对于a和b作为两个DateTime类型:

DateTime d = DateTime.Now;
DateTime c = DateTime.Now;
c = d.AddDays(145);
string cc;
Console.WriteLine(d);
Console.WriteLine(c);
var t = (c - d).Days;
Console.WriteLine(t);
cc = Console.ReadLine();