Objetos DateTime¶
Vários objetos de data e hora são fornecidos pelo módulo datetime. Antes de usar qualquer uma dessas funções, o arquivo de cabeçalho datetime.h deve ser incluído na sua fonte (observe que isso não é incluído por Python.h) e a macro PyDateTime_IMPORT deve ser chamada, geralmente como parte da função de inicialização do módulo. A macro coloca um ponteiro para uma estrutura C em uma variável estática, PyDateTimeAPI, usada pelas macros a seguir.
-
type PyDateTime_DateTime¶
Esta é uma instância de
PyObjectrepresentando o objeto datetime do Python.
-
type PyDateTime_Delta¶
Esta é uma instância de
PyObjectrepresentando a diferença entre dois valores de datetime.
-
PyTypeObject PyDateTime_DateType¶
Esta instância de
PyTypeObjectrepresenta o tipo data do Python; é o mesmo objeto quedatetime.datena camada de Python.
-
PyTypeObject PyDateTime_DateTimeType¶
Esta instância de
PyTypeObjectrepresenta o tipo datetime do Python; é o mesmo objeto quedatetime.datetimena camada de Python.
-
PyTypeObject PyDateTime_TimeType¶
Esta instância de
PyTypeObjectrepresenta o tipo hora do Python; é o mesmo objeto quedatetime.timena camada de Python.
-
PyTypeObject PyDateTime_DeltaType¶
Esta instância de
PyTypeObjectrepresenta o tipo Python para a diferença entre dois valores de datetime; é o mesmo objeto quedatetime.timedeltana camada de Python.
-
PyTypeObject PyDateTime_TZInfoType¶
Esta instância de
PyTypeObjectrepresenta o tipo fuso horário do Python; é o mesmo objeto quedatetime.tzinfona camada de Python.
Macro para acesso ao singleton UTC:
-
PyObject *PyDateTime_TimeZone_UTC¶
Retorna um singleton do fuso horário representando o UTC, o mesmo objeto que
datetime.timezone.utc.Adicionado na versão 3.7.
Macros de verificação de tipo:
-
int PyDate_Check(PyObject *ob)¶
Retorna verdadeiro se ob for do tipo
PyDateTime_DateTypeou um subtipo dePyDateTime_DateType. ob não deve serNULL. Esta função sempre tem sucesso.
-
int PyDate_CheckExact(PyObject *ob)¶
Retorna verdadeiro se ob for do tipo
PyDateTime_DateType. ob não deve serNULL. Esta função sempre tem sucesso.
-
int PyDateTime_Check(PyObject *ob)¶
Retorna verdadeiro se ob é do tipo
PyDateTime_DateTimeTypeou um subtipo dePyDateTime_DateTimeType. ob não deve serNULL. Esta função sempre tem sucesso.
-
int PyDateTime_CheckExact(PyObject *ob)¶
Retorna verdadeiro se ob for do tipo
PyDateTime_DateTimeType. ob não deve serNULL. Esta função sempre tem sucesso.
-
int PyTime_Check(PyObject *ob)¶
Retorna verdadeiro se ob é do tipo
PyDateTime_TimeTypeou um subtipo dePyDateTime_TimeType. ob não deve serNULL. Esta função sempre tem sucesso.
-
int PyTime_CheckExact(PyObject *ob)¶
Retorna verdadeiro se ob for do tipo
PyDateTime_TimeType. ob não deve serNULL. Esta função sempre tem sucesso.
-
int PyDelta_Check(PyObject *ob)¶
Retorna verdadeiro se ob for do tipo
PyDateTime_DeltaTypeou um subtipo dePyDateTime_DeltaType. ob não pode serNULL. Esta função sempre tem sucesso.
-
int PyDelta_CheckExact(PyObject *ob)¶
Retorna verdadeiro se ob for do tipo
PyDateTime_DeltaType. ob não deve serNULL. Esta função sempre tem sucesso.
-
int PyTZInfo_Check(PyObject *ob)¶
Retorna verdadeiro se ob for do tipo
PyDateTime_TZInfoTypeou um subtipo dePyDateTime_TZInfoType. ob não pode serNULL. Esta função sempre tem sucesso.
-
int PyTZInfo_CheckExact(PyObject *ob)¶
Retorna verdadeiro se ob for do tipo
PyDateTime_TZInfoType. ob não deve serNULL. Esta função sempre tem sucesso.
Macros para criar objetos:
-
PyObject *PyDate_FromDate(int year, int month, int day)¶
- Retorna valor: Nova referência.
Retorna um objeto
datetime.datecom o ano, mês e dia especificados.
-
PyObject *PyDateTime_FromDateAndTime(int year, int month, int day, int hour, int minute, int second, int usecond)¶
- Retorna valor: Nova referência.
Retorna um objeto
datetime.datetimecom o ano, mês, dia, hora, minuto, segundo, microssegundo especificados.
-
PyObject *PyDateTime_FromDateAndTimeAndFold(int year, int month, int day, int hour, int minute, int second, int usecond, int fold)¶
- Retorna valor: Nova referência.
Retorna um objeto
datetime.datetimecom o ano, mês, dia, hora, minuto, segundo, microssegundo e a dobra especificados.Adicionado na versão 3.6.
-
PyObject *PyTime_FromTime(int hour, int minute, int second, int usecond)¶
- Retorna valor: Nova referência.
Retorna um objeto
datetime.timecom a hora, minuto, segundo e microssegundo especificados.
-
PyObject *PyTime_FromTimeAndFold(int hour, int minute, int second, int usecond, int fold)¶
- Retorna valor: Nova referência.
Retorna um objeto
datetime.timecom a hora, minuto, segundo, microssegundo e a dobra especificados.Adicionado na versão 3.6.
-
PyObject *PyDelta_FromDSU(int days, int seconds, int useconds)¶
- Retorna valor: Nova referência.
Retorna um objeto
datetime.timedeltarepresentando o número especificado de dias, segundos e microssegundos. A normalização é realizada para que o número resultante de microssegundos e segundos esteja nos intervalos documentados para objetos dedatetime.timedelta.
-
PyObject *PyTimeZone_FromOffset(PyObject *offset)¶
- Retorna valor: Nova referência.
Retorna um objeto
datetime.timezonecom um deslocamento fixo sem nome representado pelo argumento offset.Adicionado na versão 3.7.
-
PyObject *PyTimeZone_FromOffsetAndName(PyObject *offset, PyObject *name)¶
- Retorna valor: Nova referência.
Retorna um objeto
datetime.timezonecom um deslocamento fixo representado pelo argumento offset e com tzname name.Adicionado na versão 3.7.
Macros para extrair campos de objetos date. O argumento deve ser uma instância de PyDateTime_Date, inclusive subclasses (como PyDateTime_DateTime). O argumento não deve ser NULL, e o tipo não é verificado:
-
int PyDateTime_GET_YEAR(PyDateTime_Date *o)¶
Retorna o ano, como um inteiro positivo.
-
int PyDateTime_GET_MONTH(PyDateTime_Date *o)¶
Retorna o mês, como um inteiro de 1 a 12.
-
int PyDateTime_GET_DAY(PyDateTime_Date *o)¶
Retorna o dia, como um inteiro de 1 a 31.
Macros para extrair campos de objetos datetime. O argumento deve ser uma instância de PyDateTime_DateTime, inclusive subclasses. O argumento não deve ser NULL, e o tipo não é verificado:
-
int PyDateTime_DATE_GET_HOUR(PyDateTime_DateTime *o)¶
Retorna a hora, como um inteiro de 0 a 23.
-
int PyDateTime_DATE_GET_MINUTE(PyDateTime_DateTime *o)¶
Retorna o minuto, como um inteiro de 0 a 59.
-
int PyDateTime_DATE_GET_SECOND(PyDateTime_DateTime *o)¶
Retorna o segundo, como um inteiro de 0 a 59.
-
int PyDateTime_DATE_GET_MICROSECOND(PyDateTime_DateTime *o)¶
Retorna o microssegundo, como um inteiro de 0 a 999999.
-
int PyDateTime_DATE_GET_FOLD(PyDateTime_DateTime *o)¶
Retorna a dobra, como um inteiro de 0 a 1.
Adicionado na versão 3.6.
-
PyObject *PyDateTime_DATE_GET_TZINFO(PyDateTime_DateTime *o)¶
Retorna o tzinfo (que pode ser
None).Adicionado na versão 3.10.
Macros para extrair campos de objetos time. O argumento deve ser uma instância de PyDateTime_Time, inclusive subclasses. O argumento não deve ser NULL, e o tipo não é verificado:
-
int PyDateTime_TIME_GET_HOUR(PyDateTime_Time *o)¶
Retorna a hora, como um inteiro de 0 a 23.
-
int PyDateTime_TIME_GET_MINUTE(PyDateTime_Time *o)¶
Retorna o minuto, como um inteiro de 0 a 59.
-
int PyDateTime_TIME_GET_SECOND(PyDateTime_Time *o)¶
Retorna o segundo, como um inteiro de 0 a 59.
-
int PyDateTime_TIME_GET_MICROSECOND(PyDateTime_Time *o)¶
Retorna o microssegundo, como um inteiro de 0 a 999999.
-
int PyDateTime_TIME_GET_FOLD(PyDateTime_Time *o)¶
Retorna a dobra, como um inteiro de 0 a 1.
Adicionado na versão 3.6.
-
PyObject *PyDateTime_TIME_GET_TZINFO(PyDateTime_Time *o)¶
Retorna o tzinfo (que pode ser
None).Adicionado na versão 3.10.
Macros para extrair campos de objetos time delta. O argumento deve ser uma instância de PyDateTime_Delta, inclusive subclasses. O argumento não deve ser NULL, e o tipo não é verificado:
-
int PyDateTime_DELTA_GET_DAYS(PyDateTime_Delta *o)¶
Retorna o número de dias, como um inteiro de -999999999 a 999999999.
Adicionado na versão 3.3.
-
int PyDateTime_DELTA_GET_SECONDS(PyDateTime_Delta *o)¶
Retorna o número de segundos, como um inteiro de 0 a 86399.
Adicionado na versão 3.3.
-
int PyDateTime_DELTA_GET_MICROSECONDS(PyDateTime_Delta *o)¶
Retorna o número de microssegundos, como um inteiro de 0 a 999999.
Adicionado na versão 3.3.
Macros para a conveniência de módulos implementando a API de DB:
-
PyObject *PyDateTime_FromTimestamp(PyObject *args)¶
- Retorna valor: Nova referência.
Cria e retorna um novo objeto
datetime.datetimedado uma tupla de argumentos que possa ser passada ao métododatetime.datetime.fromtimestamp().
-
PyObject *PyDate_FromTimestamp(PyObject *args)¶
- Retorna valor: Nova referência.
Cria e retorna um novo objeto
datetime.datedado uma tupla de argumentos que possa ser passada ao métododatetime.date.fromtimestamp().