我正在从数据库中检索两个日期时间值。一旦检索到值,我需要两个值之间的差值。 为此,我创建了一个时间跨度变量来存储两个日期值的差值。

TimeSpan? variable = datevalue1 - datevalue2;

现在我需要显示在Timespan变量中存储的小时数的差异。 我提到了TimeSpan。TotalHours,但由于某种原因不能应用相同的。 我怎么做呢? 我在MVC项目上使用c#。我需要简单地显示小时的差异值?

编辑: 由于时间跨度是空的,我不能使用总小时属性。现在我可以通过timeespanval。value。totalhours来使用它;


当前回答

一个更精确的方式为员工支付工时或其他精度要求::

decimal DeterminePreciseHours(DateTime startTimestamp, DateTime stopTimestamp)
{
    var span = (stopTimestamp - startTimestamp).Value;
    decimal total = (decimal)span.TotalMilliseconds / 60 / 60 / 1000;
    return Math.Round(total, PRECISION_CONSTANT);
}

https://dotnetfiddle.net/tVIoVJ

其他回答

哇,我得说:保持简单:

MessageBox.Show("Result: " + (DateTime.Now.AddDays(10) > DateTime.Now));

Result: True

and:

MessageBox.Show("Result: " + DateTime.Now.AddDays(10).Subtract(DateTime.Now));

Result: 10.00:00:00

DateTime对象具有处理布尔结果的所有内置逻辑。

一个更精确的方式为员工支付工时或其他精度要求::

decimal DeterminePreciseHours(DateTime startTimestamp, DateTime stopTimestamp)
{
    var span = (stopTimestamp - startTimestamp).Value;
    decimal total = (decimal)span.TotalMilliseconds / 60 / 60 / 1000;
    return Math.Round(total, PRECISION_CONSTANT);
}

https://dotnetfiddle.net/tVIoVJ

var startTime = new TimeSpan(6, 0, 0); // 6:00 AM
var endTime = new TimeSpan(5, 30, 0); // 5:30 AM 
var hours24 = new TimeSpan(24, 0, 0);
var difference = endTime.Subtract(startTime); // (-00:30:00)
difference = (difference.Duration() != difference) ? hours24.Subtract(difference.Duration()) : difference; // (23:30:00)

如果我们比较两个不同的日期,还可以添加日期之间的差异吗

new TimeSpan(24 * days, 0, 0)

这是另一个在c#中减去两个日期的例子…

if ( DateTime.Now.Subtract(Convert.ToDateTime(objDateValueFromDatabase.CreatedOn)).TotalHours > 24 ) 
{ 
... 
} 

你可能还想看看

var hours = (datevalue1 - datevalue2).TotalHours;