Q 语言 - 时态数据

q 语言有许多不同的方式来表示和操作时间数据(例如时间和日期)。

日期

kdb+ 中的日期在内部存储为自我们的参考日期为 2000 年 1 月 1 日以来的整数天数。 此日期之后的日期在内部存储为正数,而在此日期之前的日期被引用为负数。

默认情况下,日期以"YYYY.MM.DD"格式写入

q)x:2015.01.22      / This is how we write 22nd Jan 2015

q)`int$x            / Number of days since 2000.01.01
5500i

q)`year$x           / Extracting year from the date
2015i

q)x.year            / Another way of extracting year
2015i

q)`mm$x             / Extracting month from the date
1i

q)x.mm              / Another way of extracting month
1i

q)`dd$x             / Extracting day from the date
22i

q)x.dd              / Another way of extracting day
22i

算术和逻辑运算可以直接对日期进行。

q)x+1        / Add one day
2015.01.23

q)x-7        / Subtract 7 days
2015.01.15

2000 年 1 月 1 日是星期六。 因此,历史上或将来的任何星期六除以 7 时都会得到余数 0,星期日得到 1,星期一得到 2。

             Day               mod 7
           Saturday              0
           Sunday                1
           Monday                2
           Tuesday               3
           Wednesday             4
           Thursday              5
           Friday                6

时间

时间在内部存储为自午夜钟声敲响以来的整数毫秒数。 时间以 HH:MM:SS.MSS 格式写入

q)tt1: 03:30:00.000     / tt1 store the time 03:30 AM

q)tt1
03:30:00.000

q)`int$tt1              / Number of milliseconds in 3.5 hours
12600000i

q)`hh$tt1               / Extract the hour component from time
3i

q)tt1.hh
3i

q)`mm$tt1               / Extract the minute component from time
30i

q)tt1.mm
30i

q)`ss$tt1               / Extract the second component from time
0i

q)tt1.ss
0i

与日期一样,可以直接对时间进行算术运算。

日期时间

日期时间是日期和时间的组合,按照 ISO 标准格式,以"T"分隔。 日期时间值存储从 2000 年 1 月 1 日午夜开始的小数天数。

q)dt:2012.12.20T04:54:59:000      / 04:54.59 AM on 20thDec2012

q)type dt
-15h

q)dt
2012.12.20T04:54:59.000
9
q)`float$dt
4737.205

可以通过转换为浮点数来获取基础的小数天数。