DOTNET的舍入日期时间到最后15分钟日期、时间、DOTNET

2023-09-05 03:56:48 作者:暧昧蔠荿傷

有一个函数四舍五入日期时间到最后一个季度?

Is there a function to round off the datetime to last quarter?

示例...

08:03:00 becomes 08:00:00

08:14:00 becomes 08:00:00

08:15:00 stays   08:15:00

08:16:00 becomes 08:15:00

08:29:00 becomes 08:15:00

08:45:00 stays   08:45:00 

08:55:00 becomes 08:45:00

09:01:00 becomes 09:00:00

我已经写了下面的函数,但它返回下一季度

private DateTime RoundUpToPreviousQuarter(DateTime date, TimeSpan d)
{
      return new DateTime(((date.Ticks + d.Ticks - 1) / d.Ticks) * d.Ticks);
}

// call the method
this.RoundUp(time, TimeSpan.FromMinutes(15));

任何输入AP preciated。

Any inputs appreciated.

推荐答案

应用模15日期时间的分钟财产,减去相同的属性值

Apply the modulo 15 to the datetime Minute property and subtract that value from the same property

DateTime dt = new DateTime(2013,5,28, 15, 59,0);
dt = dt.AddMinutes(-(dt.Minute % 15));

在这个例子中,我创建了一个零秒的日期时间。如果您还需要去除秒

In this example I have created a zero seconds datetime. If you need to remove also the seconds

DateTime dt = new DateTime(2013,5,28, 15, 59,45);
dt = dt.AddMinutes(-(dt.Minute % 15)).AddSeconds(-dt.Second);