我想计算一对舍入到最接近的秒或分钟的DateTimes之间的差异。
initial = now()
println(typeof(initial))
sleep(12)
final = now()
difference = final - initial
println(typeof(difference))
给出
DateTime
Base.Dates.Millisecond
后一种类型非常难以使用,因为几乎所有便利类型都适用于DateTime
。将difference
转换为秒或小数分钟的推荐方法是什么?这可能没有下降到整数吗?我宁愿避免这种情况,因为它更容易出错。
答案 0 :(得分:3)
由于difference
表示日期而不是特定时间之间的持续时间,因此它只是一个持续时间(以毫秒为单位)。此外,DateTime
和Base.Dates.Millisecond
对象在内部用Int64
表示,所以一切都已经是整数。
julia> moment = now()
2016-12-22T22:54:57.393
julia> dump(moment)
DateTime
instant: Base.Dates.UTInstant{Base.Dates.Millisecond}
periods: Base.Dates.Millisecond
value: Int64 63618130497393
julia> dump(now()-moment)
Base.Dates.Millisecond
value: Int64 29820
将以毫秒为单位的值除以1000得到秒,或者除以60,000得到分钟。使用round()
舍入到最近的秒或分钟。
julia> d = (now() - moment).value/60_000
3.9330833333333333
julia> e = round(d)
4.0
然后乘以1000或60,000并将其反馈回Dates.Millisecond
以将圆形图形转回适当的对象:
julia> Dates.Millisecond(60_000e)
240000 milliseconds
将Date
或DateTime
对象舍入到给定的时间间隔要简单得多,因为您可以根据documentation使用round()
并将其发送到相关方法:
julia> floor(Date(1985, 8, 16), Dates.Month) 1985-08-01 julia> ceil(DateTime(2013, 2, 13, 0, 31, 20), Dates.Minute(15)) 2013-02-13T00:45:00 julia> round(DateTime(2016, 8, 6, 20, 15), Dates.Day) 2016-08-07T00:00:00