time.struct_time 结构
0
tm_year
(for example, 1993)(下注)
1
tm_mon
range [1, 12](下注)
2
tm_mday
range [1, 31]
3
tm_hour
range [0, 23]
4
tm_min
range [0, 59]
5
tm_sec
range [0, 61](下注)
6
tm_wday
range [0, 6], Monday is 0
7
tm_yday
range [1, 366]
8
tm_isdst
0, 1 or -1; see below
如果在函数中使用该元组时使用了错误的长度或者使用错误的类型,会引发TypeError 错误。
注:
上面表中,tm_sec 中的取值范围为 0~61, 这并不是写错了!是考虑了闰秒和双闰秒的因素(非常少见)。(关于闰秒,英文leap seconds,这是来自百度百科的解释: 闰秒是指为保持协调世界时接近于世界时时刻,由国际计量局统一规定在年底或年中对协调世界时增加或减少1秒>的调整。由于地球自转的不均匀性和长期变慢性,会使世界时(民用时)和原子时之间相差超过到±0.9秒时,就把世界时向前拨1秒(负闰秒,最后一分钟为59秒)或向后拨1秒(正闰秒,最后一分钟为61秒))
与C 结构不同,月对应的值范围是1~12,而不是0~11。
年的值需要注意以下问题:Python 依赖于平台的C 库,C 库一般是没有2000年的问题的,因为所有的日期和时间都内在的代表自时代以来的秒。函数接收上面一个struct_time 结构,其中需要4位来表示年。为了向后兼容,如果模块变量accept2dyear 是一个非零整数,支持使用2位来表示年;而这个变量会被初始化为1,除非环境变量PYTHONY2K 被设置为一个非空的字符串,之后PYTHONY2K 被设置时变量 accept2dyear 才会被初始化为0。
因此,你可以将PYTHONY2K 设置为一个非空字符串从而使得python 对于任何年的输入都使用4位来表示。否则,如果使用的是2位表示年,将会根据POSIX 或者X/Open 标准来转换:69~99 被映射为1969~1999,而0~68 被映射为2000~2068。(此问题在Python的 time模块介绍中标记为“Year 2000 (Y2K) issues” )