DateTime 对象¶
datetime 模块提供了各种日期和时间对象。 在使用任何这些函数之前,必须在你的源码中包含头文件 datetime.h (请注意此文件并未包含在 Python.h 中),并且宏 PyDateTime_IMPORT 必须被发起调用,通常是作为模块初始化函数的一部分。 这个宏会将指向特定 C 结构的指针放入一个静态变量 PyDateTimeAPI 中,它会由下面的宏来使用。
宏访问UTC单例:
- 
PyObject* PyDateTime_TimeZone_UTC¶
- 返回表示 UTC 的时区单例,与 - datetime.timezone.utc为同一对象。- 3.7 新版功能. 
类型检查宏:
- 
int PyDate_Check(PyObject *ob)¶
- 如果 ob 为 - PyDateTime_DateType类型或- PyDateTime_DateType的某个子类型则返回真值。 ob 不能为- NULL。
- 
int PyDateTime_Check(PyObject *ob)¶
- 如果 ob 为 - PyDateTime_DateTimeType类型或- PyDateTime_DateTimeType的某个子类型则返回真值。 ob 不能为- NULL。
- 
int PyTime_Check(PyObject *ob)¶
- 如果 ob 的类型是 - PyDateTime_TimeType或是- PyDateTime_TimeType的子类型则返回真值。 ob 必须不为- NULL。
- 
int PyDelta_Check(PyObject *ob)¶
- 如果 ob 为 - PyDateTime_DeltaType类型或- PyDateTime_DeltaType的某个子类型则返回真值。 ob 不能为- NULL。
- 
int PyTZInfo_Check(PyObject *ob)¶
- 如果 ob 为 - PyDateTime_TZInfoType类型或- PyDateTime_TZInfoType的某个子类型则返回真值。 ob 必须不为- NULL。
用于创建对象的宏:
- 
PyObject* PyDate_FromDate(int year, int month, int day)¶
- Return value: New reference.返回指定年、月、日的 datetime.date对象。
- 
PyObject* PyDateTime_FromDateAndTime(int year, int month, int day, int hour, int minute, int second, int usecond)¶
- Return value: New reference.返回具有指定年、周、日、时、分、秒和微秒的 datetime.datetime对象。
- 
PyObject* PyDateTime_FromDateAndTimeAndFold(int year, int month, int day, int hour, int minute, int second, int usecond, int fold)¶
- Return value: New reference.返回具有指定 year, month, day, hour, minute, second, microsecond 和 fold 属性的 datetime.datetime对象。3.6 新版功能. 
- 
PyObject* PyTime_FromTime(int hour, int minute, int second, int usecond)¶
- Return value: New reference.返回具有指定 hour, minute, second and microsecond 属性的 datetime.time对象。
- 
PyObject* PyTime_FromTimeAndFold(int hour, int minute, int second, int usecond, int fold)¶
- Return value: New reference.返回具有指定 hour, minute, second, microsecond 和 fold 属性的 datetime.time对象。3.6 新版功能. 
- 
PyObject* PyDelta_FromDSU(int days, int seconds, int useconds)¶
- Return value: New reference.返回代表给定天、秒和微秒数的 datetime.timedelta对象。 将执行正规化操作以使最终的微秒和秒数处在datetime.timedelta对象的文档指明的区间之内。
- 
PyObject* PyTimeZone_FromOffset(PyDateTime_DeltaType* offset)¶
- Return value: New reference.返回一个 datetime.timezone对象,该对象带有以 offset 参数表示 的未命名固定时差。3.7 新版功能. 
- 
PyObject* PyTimeZone_FromOffsetAndName(PyDateTime_DeltaType* offset, PyUnicode* name)¶
- Return value: New reference.返回一个 datetime.timezone对象,该对象具有以 offset 参数表示的固定时差和时区名称 name。3.7 新版功能. 
一些用来从 date 对象中提取字段的宏。 参数必须是 PyDateTime_Date 包括其子类 (例如 PyDateTime_DateTime) 的实例。 参数必须不为 NULL,并且类型不被会检查:
- 
int PyDateTime_GET_YEAR(PyDateTime_Date *o)¶
- 以正整数的形式返回年份值。 
- 
int PyDateTime_GET_MONTH(PyDateTime_Date *o)¶
- 返回月,从0到12的整数。 
- 
int PyDateTime_GET_DAY(PyDateTime_Date *o)¶
- 返回日期,从0到31的整数。 
一些用来从 datetime 对象中提取字段的宏。 参数必须是 PyDateTime_DateTime 包括其子类的实例。 参数必须不为 NULL,并且类型不会被检查:
- 
int PyDateTime_DATE_GET_HOUR(PyDateTime_DateTime *o)¶
- 返回小时,从0到23的整数。 
- 
int PyDateTime_DATE_GET_MINUTE(PyDateTime_DateTime *o)¶
- 返回分钟,从0到59的整数。 
- 
int PyDateTime_DATE_GET_SECOND(PyDateTime_DateTime *o)¶
- 返回秒,从0到59的整数。 
- 
int PyDateTime_DATE_GET_MICROSECOND(PyDateTime_DateTime *o)¶
- 返回微秒,从0到999999的整数。 
一些用来从 time 对象中提取字段的宏。 参数必须是 PyDateTime_Time 包括其子类的实例。 参数必须不为 NULL,并且类型不会被检查:
- 
int PyDateTime_TIME_GET_HOUR(PyDateTime_Time *o)¶
- 返回小时,从0到23的整数。 
- 
int PyDateTime_TIME_GET_MINUTE(PyDateTime_Time *o)¶
- 返回分钟,从0到59的整数。 
- 
int PyDateTime_TIME_GET_SECOND(PyDateTime_Time *o)¶
- 返回秒,从0到59的整数。 
- 
int PyDateTime_TIME_GET_MICROSECOND(PyDateTime_Time *o)¶
- 返回微秒,从0到999999的整数。 
一些用来从 timedelta 对象中提取字段的宏。 参数必须是 PyDateTime_Delta 包括其子类的实例。 参数必须不为 NULL,并且类型不会被检查:
- 
int PyDateTime_DELTA_GET_DAYS(PyDateTime_Delta *o)¶
- 返回天数,从-999999999到999999999的整数。 - 3.3 新版功能. 
- 
int PyDateTime_DELTA_GET_SECONDS(PyDateTime_Delta *o)¶
- 返回秒数,从0到86399的整数。 - 3.3 新版功能. 
- 
int PyDateTime_DELTA_GET_MICROSECONDS(PyDateTime_Delta *o)¶
- 返回微秒数,从0到999999的整数。 - 3.3 新版功能. 
一些便于模块实现 DB API 的宏:
- 
PyObject* PyDateTime_FromTimestamp(PyObject *args)¶
- Return value: New reference.创建并返回一个给定元组参数的新 datetime.datetime对象,适合传给datetime.datetime.fromtimestamp()。
- 
PyObject* PyDate_FromTimestamp(PyObject *args)¶
- Return value: New reference.创建并返回一个给定元组参数的新 datetime.date对象,适合传给datetime.date.fromtimestamp()。
