Objetos Inteiros¶
Todos os inteiros são implementados como objetos inteiros “longos” de tamanho arbitrário.
Em caso de erro, a maioria das APIs PyLong_As* retorna (tipo de retorno)-1 que não pode ser distinguido de um número. Use PyErr_Occurred() para desambiguar.
-
PyTypeObject
PyLong_Type¶ Esta instância de
PyTypeObjectrepresenta o tipo inteiro Python. Este é o mesmo objeto queintna camada Python.
-
int
PyLong_Check(PyObject *p)¶ Retorna true se seu argumento é um
PyLongObjectou um subtipo dePyLongObject.
-
int
PyLong_CheckExact(PyObject *p)¶ Retorna true se seu argumento é um
PyLongObject, mas não um subtipo dePyLongObject.
-
PyObject*
PyLong_FromLong(long v)¶ - Return value: New reference.
Return a new
PyLongObjectobject from v, or NULL on failure.The current implementation keeps an array of integer objects for all integers between
-5and256, when you create an int in that range you actually just get back a reference to the existing object. So it should be possible to change the value of1. I suspect the behaviour of Python in this case is undefined. :-)
-
PyObject*
PyLong_FromUnsignedLong(unsigned long v)¶ - Return value: New reference.
Return a new
PyLongObjectobject from a Cunsigned long, or NULL on failure.
-
PyObject*
PyLong_FromSsize_t(Py_ssize_t v)¶ Return a new
PyLongObjectobject from a CPy_ssize_t, or NULL on failure.
-
PyObject*
PyLong_FromSize_t(size_t v)¶ Return a new
PyLongObjectobject from a Csize_t, or NULL on failure.
-
PyObject*
PyLong_FromLongLong(long long v)¶ - Return value: New reference.
Return a new
PyLongObjectobject from a Clong long, or NULL on failure.
-
PyObject*
PyLong_FromUnsignedLongLong(unsigned long long v)¶ - Return value: New reference.
Return a new
PyLongObjectobject from a Cunsigned long long, or NULL on failure.
-
PyObject*
PyLong_FromDouble(double v)¶ - Return value: New reference.
Return a new
PyLongObjectobject from the integer part of v, or NULL on failure.
-
PyObject*
PyLong_FromString(const char *str, char **pend, int base)¶ - Return value: New reference.
Return a new
PyLongObjectbased on the string value in str, which is interpreted according to the radix in base. If pend is non-NULL, *pend will point to the first character in str which follows the representation of the number. If base is0, str is interpreted using the Inteiros Literais definition; in this case, leading zeros in a non-zero decimal number raises aValueError. If base is not0, it must be between2and36, inclusive. Leading spaces and single underscores after a base specifier and between digits are ignored. If there are no digits,ValueErrorwill be raised.
-
PyObject*
PyLong_FromUnicode(Py_UNICODE *u, Py_ssize_t length, int base)¶ - Return value: New reference.
Convert a sequence of Unicode digits to a Python integer value. The Unicode string is first encoded to a byte string using
PyUnicode_EncodeDecimal()and then converted usingPyLong_FromString().Deprecated since version 3.3, will be removed in version 4.0: Parte do estilo antigo
Py_UNICODEAPI; por favor, migre o uso paraPyLong_FromUnicodeObject().
-
PyObject*
PyLong_FromUnicodeObject(PyObject *u, int base)¶ Convert a sequence of Unicode digits in the string u to a Python integer value. The Unicode string is first encoded to a byte string using
PyUnicode_EncodeDecimal()and then converted usingPyLong_FromString().Novo na versão 3.3.
-
PyObject*
PyLong_FromVoidPtr(void *p)¶ - Return value: New reference.
Cria um inteiro Python a partir do ponteiro p. O valor do ponteiro pode ser recuperado do valor resultante usando
PyLong_AsVoidPtr().
-
long
PyLong_AsLong(PyObject *obj)¶ Return a C
longrepresentation of obj. If obj is not an instance ofPyLongObject, first call its__int__()method (if present) to convert it to aPyLongObject.Levanta
OverflowErrorse o valor de obj estiver fora do intervalo de umlong.Retorna
-1no caso de erro. UsePyErr_Occurred()para desambiguar.
-
long
PyLong_AsLongAndOverflow(PyObject *obj, int *overflow)¶ Return a C
longrepresentation of obj. If obj is not an instance ofPyLongObject, first call its__int__()method (if present) to convert it to aPyLongObject.Se o valor de obj for maior que
LONG_MAXou menor queLONG_MIN, define *overflow para1ou-1, respectivamente, e retorna-1; caso contrário, define *overflow para0. Se qualquer outra exceção ocorrer, define *overflow para0e retorne-1como de costume.Retorna
-1no caso de erro. UsePyErr_Occurred()para desambiguar.
-
long long
PyLong_AsLongLong(PyObject *obj)¶ Return a C
long longrepresentation of obj. If obj is not an instance ofPyLongObject, first call its__int__()method (if present) to convert it to aPyLongObject.Levanta
OverflowErrorse o valor de obj estiver fora do intervalo de umlong.Retorna
-1no caso de erro. UsePyErr_Occurred()para desambiguar.
-
long long
PyLong_AsLongLongAndOverflow(PyObject *obj, int *overflow)¶ Return a C
long longrepresentation of obj. If obj is not an instance ofPyLongObject, first call its__int__()method (if present) to convert it to aPyLongObject.If the value of obj is greater than
PY_LLONG_MAXor less thanPY_LLONG_MIN, set *overflow to1or-1, respectively, and return-1; otherwise, set *overflow to0. If any other exception occurs set *overflow to0and return-1as usual.Retorna
-1no caso de erro. UsePyErr_Occurred()para desambiguar.Novo na versão 3.2.
-
Py_ssize_t
PyLong_AsSsize_t(PyObject *pylong)¶ Retorna uma representação de
Py_ssize_tC de pylong. pylong deve ser uma instância dePyLongObject.Levanta
OverflowErrorse o valor de pylong estiver fora do intervalo de umPy_ssize_t.Retorna
-1no caso de erro. UsePyErr_Occurred()para desambiguar.
-
unsigned long
PyLong_AsUnsignedLong(PyObject *pylong)¶ Retorna uma representação de
unsigned longC de pylong. pylong deve ser uma instância dePyLongObject.Levanta
OverflowErrorse o valor de pylong estiver fora do intervalo de umunsigned long.Retorna
(unsigned long)-1no caso de erro. UsePyErr_Occurred()para desambiguar.
-
size_t
PyLong_AsSize_t(PyObject *pylong)¶ Retorna uma representação de
size_tC de pylong. pylong deve ser uma instância dePyLongObject.Levanta
OverflowErrorse o valor de pylong estiver fora do intervalo de umsize_t.Retorna
(size)-1no caso de erro. UsePyErr_Occurred()para desambiguar.
-
unsigned long long
PyLong_AsUnsignedLongLong(PyObject *pylong)¶ Retorna uma representação de
unsigned long longC de pylong. pylong deve ser uma instância dePyLongObject.Levanta
OverflowErrorse o valor de pylong estiver fora do intervalo de umunsigned long long.Retorna
(unsigned long long)-1no caso de erro. UsePyErr_Occurred()para desambiguar.Alterado na versão 3.1: Um pylong negativo agora levanta
OverflowError, nãoTypeError.
-
unsigned long
PyLong_AsUnsignedLongMask(PyObject *obj)¶ Return a C
unsigned longrepresentation of obj. If obj is not an instance ofPyLongObject, first call its__int__()method (if present) to convert it to aPyLongObject.Se o valor de obj estiver fora do intervalo para um
unsigned long, retorna a redução desse módulo de valorULONG_MAX + 1.Retorna
-1no caso de erro. UsePyErr_Occurred()para desambiguar.
-
unsigned long long
PyLong_AsUnsignedLongLongMask(PyObject *obj)¶ Return a C
unsigned long longrepresentation of obj. If obj is not an instance ofPyLongObject, first call its__int__()method (if present) to convert it to aPyLongObject.If the value of obj is out of range for an
unsigned long long, return the reduction of that value moduloPY_ULLONG_MAX + 1.Retorna
-1no caso de erro. UsePyErr_Occurred()para desambiguar.
-
double
PyLong_AsDouble(PyObject *pylong)¶ Retorna uma representação de
doubleC de pylong. pylong deve ser uma instância dePyLongObject.Levanta
OverflowErrorse o valor de pylong estiver fora do intervalo de umdouble.Retorna
-1.0no caso de erro. UsePyErr_Occurred()para desambiguar.
-
void*
PyLong_AsVoidPtr(PyObject *pylong)¶ Converte um inteiro Python pylong em um ponteiro
voidC. Se pylong não puder ser convertido, umaOverflowErrorserá levantada. Isso só é garantido para produzir um ponteiro utilizávelvoidpara valores criados comPyLong_FromVoidPtr().Returns NULL on error. Use
PyErr_Occurred()to disambiguate.
