我一直在寻找一个合适的舍入机制,但我发现的任何东西似乎都不是我需要的。
我需要分别向上和向下舍入,我还需要考虑已经四舍五入的情况。
我需要进行以下四舍五入
5:00 -> RoundDown() -> 5:00
5:04 -> RoundDown() -> 5:00
5:09 -> RoundDown() -> 5:00
5:10 -> RoundDown() -> 5:10
4:00 -> RoundUp() -> 4:00
4:50 -> RoundUp() -> 4:50
4:51 -> RoundUp() -> 5:00
4:56 -> RoundUp() -> 5:00
基本上我需要将RoundUp()或RoundDown()显式地提交到最近的10分钟,但如果它已经是10分钟的倍数,它也应该保持时间不变。另外,我想截断它们对舍入过程没有影响的任何秒数
4:50:45 - > 4:50:00 - > RoundUp() - > 4:50
有没有人有任何方便的代码来实现这一目标。
我在某个地方发现了这个代码,但它在5点到了 - >> RoundUp() - > 5:10而不是保持原样,因为它已经是10的倍数,不需要四舍五入。我也不确定秒会影响它
public static DateTime RoundDateTime(this DateTime dt, int minutes, RoundingDirection direction)
{
TimeSpan t;
switch (direction)
{
case RoundingDirection.Up:
t = (dt.Subtract(DateTime.MinValue)).Add(new TimeSpan(0, minutes, 0)); break;
case RoundingDirection.Down:
t = (dt.Subtract(DateTime.MinValue)); break;
default:
t = (dt.Subtract(DateTime.MinValue)).Add(new TimeSpan(0, minutes / 2, 0)); break;
}
return DateTime.MinValue.Add(new TimeSpan(0,
(((int)t.TotalMinutes) / minutes) * minutes, 0));
}
希望有人可以编辑该方法,使其适合我。感谢
答案 0 :(得分:33)
这将让你按照给定的间隔进行舍入。
public static class DateTimeExtensions
{
public static DateTime Floor(this DateTime dateTime, TimeSpan interval)
{
return dateTime.AddTicks(-(dateTime.Ticks % interval.Ticks));
}
public static DateTime Ceiling(this DateTime dateTime, TimeSpan interval)
{
var overflow = dateTime.Ticks % interval.Ticks;
return overflow == 0 ? dateTime : dateTime.AddTicks(interval.Ticks - overflow);
}
public static DateTime Round(this DateTime dateTime, TimeSpan interval)
{
var halfIntervalTicks = (interval.Ticks + 1) >> 1;
return dateTime.AddTicks(halfIntervalTicks - ((dateTime.Ticks + halfIntervalTicks) % interval.Ticks));
}
}
为了处理截断秒数,我只需从日期时间中减去秒和毫秒,然后再将它们发送到舍入函数中。
答案 1 :(得分:13)
怎么样:
case RoundingDirection.Up:
t = dt.AddMinutes((60 - dt.Minute) % 10);
case RoundingDirection.Down:
t = dt.AddMinutes(-dt.Minute % 10);
答案 2 :(得分:1)
此功能将向上或向下舍入到最近的间隔(分钟)。
private static DateTime NormalizeReadingInterval(DateTime originalTime, int interval)
{
if (originalTime.Minute % interval == 0) return originalTime;
var epochTime = new DateTime(1900, 1, 1);
var minutes = (originalTime - epochTime).TotalMinutes;
var numIntervals = minutes / interval;
var roundedNumIntervals = Math.Round(numIntervals, 0);
return epochTime.AddMinutes(roundedNumIntervals * interval);
}
答案 3 :(得分:0)
这是截断(向下舍入)的快速方法
var now = DateTime.Now;
var nowTicks = now.Ticks;
//removing the nanoseconds, miliseconds, and seconds from the nowTicks
var lastMinute = new DateTime(nowTicks - (nowTicks % (1000*1000*10*60)));
答案 4 :(得分:0)
另一种避免使用long
类型进行算术的方法。
使用整数除法,其中a和b为正整数:
a/b // rounding down
(a+b-1)/b // rounding up
((2*a)+b)/(2*b) // rounding to the nearest (0.5 up)
舍入:
public static DateTime UpToNearestXmin( DateTime dt, int block )
{
int a = dt.Minute;
int b = block;
int mins = block * (( a + b - 1 ) / b );
return new DateTime( dt.Year, dt.Month, dt.Day, dt.Hour, 0, 0 ).AddMinutes( mins );
}
要四舍五入或最接近,请适当更改分钟计算。
分钟已舍入。秒和毫秒为零,这是预期的行为。