圆形朱莉娅的毫秒类型到最接近的秒或分钟

时间:2016-12-23 00:47:45

标签: julia

我想计算一对舍入到最接近的秒或分钟的DateTimes之间的差异。

initial = now()
println(typeof(initial))
sleep(12)
final = now()
difference = final - initial
println(typeof(difference))

给出

DateTime
Base.Dates.Millisecond

后一种类型非常难以使用,因为几乎所有便利类型都适用于DateTime。将difference转换为秒或小数分钟的推荐方法是什么?这可能没有下降到整数吗?我宁愿避免这种情况,因为它更容易出错。

1 个答案:

答案 0 :(得分:3)

由于difference表示日期而不是特定时间之间的持续时间,因此它只是一个持续时间(以毫秒为单位)。此外,DateTimeBase.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

DateDateTime对象舍入到给定的时间间隔要简单得多,因为您可以根据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