Протокол номера¶
-
int
PyNumber_Check(PyObject *o)¶ Возвращает
1, если объект предоставляет o числовые протоколы, в противном случае - false. Функция всегда выполняется успешно.Изменено в версии 3.8: Возвращает
1, если o является целым индексом.
-
PyObject*
PyNumber_Add(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат добавления o1 и o2 или
NULLпри сбое. Это эквивалент Python выражениюo1 + o2.
-
PyObject*
PyNumber_Subtract(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат вычитания o2 из o1 или
NULLпри сбое. Это эквивалент Python выражениюo1 - o2.
-
PyObject*
PyNumber_Multiply(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат умножения o1 и o2 или
NULLпри отказе. Это эквивалент Python выражениюo1 * o2.
-
PyObject*
PyNumber_MatrixMultiply(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат умножения матрицы на o1 и o2 или
NULLпри отказе. Это эквивалент Python выражениюo1 @ o2.Добавлено в версии 3.5.
-
PyObject*
PyNumber_FloorDivide(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает половину o1, разделенный на o2, или
NULLпри отказе. Это эквивалентно «классическому» делению целых чисел.
-
PyObject*
PyNumber_TrueDivide(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает разумное приближение для математического значения o1, деленного на o2, или
NULLпри отказе. Возвращаемое значение является «приблизительным», поскольку двоичные числа с плавающей запятой являются приблизительными; невозможно представить все вещественные числа по основанию 2. Функция может возвращать значение с плавающей запятой при передаче двух целых чисел.
-
PyObject*
PyNumber_Remainder(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает оставшуюся часть деления o1 на o2 или
NULLпри отказе. Это эквивалент Python выражениюo1 % o2.
-
PyObject*
PyNumber_Divmod(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
См. встроенную функциональную
divmod(). ВозвращаетNULLпри отказе. Это эквивалент Python выражениюdivmod(o1, o2).
-
PyObject*
PyNumber_Power(PyObject *o1, PyObject *o2, PyObject *o3)¶ - Return value: New reference.
См. встроенную функциональную
pow(). ВозвращаетNULLпри отказе. Это эквивалент Python выражениюpow(o1, o2, o3), где o3 является необязательным. Если o3 следует игнорировать, передайтеPy_Noneвместо него (передачаNULLдля o3 приведет к незаконному доступу к памяти).
-
PyObject*
PyNumber_Negative(PyObject *o)¶ - Return value: New reference.
Возвращает отрицание o при успехе или
NULLпри сбое. Это эквивалент Python выражению-o.
-
PyObject*
PyNumber_Positive(PyObject *o)¶ - Return value: New reference.
Возвращает o при успехе или
NULLпри сбое. Это эквивалент Python выражению+o.
-
PyObject*
PyNumber_Absolute(PyObject *o)¶ - Return value: New reference.
Возвращает абсолютное значение o или
NULLпри отказе. Это эквивалент Python выражениюabs(o).
-
PyObject*
PyNumber_Invert(PyObject *o)¶ - Return value: New reference.
Возвращает побитовое отрицание o при успехе или
NULLпри сбое. Это эквивалент Python выражению~o.
-
PyObject*
PyNumber_Lshift(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат сдвига влево o1 на o2 при успехе или
NULLпри сбое. Это эквивалент Python выражениюo1 << o2.
-
PyObject*
PyNumber_Rshift(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат сдвига вправо o1 на o2 при успехе или
NULLпри сбое. Это эквивалент Python выражениюo1 >> o2.
-
PyObject*
PyNumber_And(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает побитовые и o1 и o2 при успехе и
NULLпри неудаче. Это эквивалент Python выражениюo1 & o2.
-
PyObject*
PyNumber_Xor(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает «побитовое исключение или» o1 и o2 при успехе или
NULLпри сбое. Это эквивалент Python выражениюo1 ^ o2.
-
PyObject*
PyNumber_Or(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает «побитовое или» o1 и o2 при успехе, или
NULLпри сбое. Это эквивалент Python выражениюo1 | o2.
-
PyObject*
PyNumber_InPlaceAdd(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат добавления o1 и o2 или
NULLпри сбое. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 += o2.
-
PyObject*
PyNumber_InPlaceSubtract(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат вычитания o2 из o1 или
NULLпри сбое. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 -= o2.
-
PyObject*
PyNumber_InPlaceMultiply(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат умножения o1 и o2 или
NULLпри отказе. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 *= o2.
-
PyObject*
PyNumber_InPlaceMatrixMultiply(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат умножения матрицы на o1 и o2 или
NULLпри отказе. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 @= o2.Добавлено в версии 3.5.
-
PyObject*
PyNumber_InPlaceFloorDivide(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает математический пол деления o1 на o2 или
NULLпри отказе. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 //= o2.
-
PyObject*
PyNumber_InPlaceTrueDivide(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает разумное приближение для математического значения o1, деленного на o2, или
NULLпри отказе. Возвращаемое значение является «приблизительным», поскольку двоичные числа с плавающей запятой являются приблизительными; невозможно представить все вещественные числа по основанию 2. Функция может возвращать значение с плавающей запятой при передаче двух целых чисел. Операция выполняется на месте тогда, когда o1 ее поддерживает.
-
PyObject*
PyNumber_InPlaceRemainder(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает оставшуюся часть деления o1 на o2 или
NULLпри отказе. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 %= o2.
-
PyObject*
PyNumber_InPlacePower(PyObject *o1, PyObject *o2, PyObject *o3)¶ - Return value: New reference.
См. встроенную функциональную
pow(). ВозвращаетNULLпри отказе. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 **= o2, когда o3 равноPy_None, или контекстный вариантpow(o1, o2, o3)в противном случае. Если o3 следует игнорировать, передайтеPy_Noneвместо него (передачаNULLдля o3 приведет к незаконному доступу к памяти).
-
PyObject*
PyNumber_InPlaceLshift(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат сдвига влево o1 на o2 при успехе или
NULLпри сбое. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 <<= o2.
-
PyObject*
PyNumber_InPlaceRshift(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает результат сдвига вправо o1 на o2 при успехе или
NULLпри сбое. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 >>= o2.
-
PyObject*
PyNumber_InPlaceAnd(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает побитовые и o1 и o2 при успехе и
NULLпри неудаче. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 &= o2.
-
PyObject*
PyNumber_InPlaceXor(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает «побитовое исключительное или» o1 на o2 при успехе или
NULLпри сбое. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 ^= o2.
-
PyObject*
PyNumber_InPlaceOr(PyObject *o1, PyObject *o2)¶ - Return value: New reference.
Возвращает «побитовое или» o1 и o2 при успехе, или
NULLпри сбое. Операция выполняется на месте тогда, когда o1 ее поддерживает. Это эквивалент Python инструкцииo1 |= o2.
-
PyObject*
PyNumber_Long(PyObject *o)¶ - Return value: New reference.
Возвращает o, преобразованный в целочисленный объект при успехе, или
NULLпри сбое. Это эквивалент Python выражениюint(o).
-
PyObject*
PyNumber_Float(PyObject *o)¶ - Return value: New reference.
Возвращает o, преобразованный в объект float при успешном выполнении, или
NULLпри сбое. Это эквивалент Python выражениюfloat(o).
-
PyObject*
PyNumber_Index(PyObject *o)¶ - Return value: New reference.
Возвращает o, преобразованный в Python int при успехе или
NULL, с исключениемTypeError, созданным при сбое.
-
PyObject*
PyNumber_ToBase(PyObject *n, int base)¶ - Return value: New reference.
Возвращает целое число n преобразованное по основанию base в виде строки. Аргумент base должен иметь значение 2, 8, 10 или 16. Для оснований 2, 8 или 16 возвращенная строка имеет префикс маркера основания
'0b','0o'или'0x'соответственно. Если n не является Python int, он преобразуется вPyNumber_Index()первым.
-
Py_ssize_t
PyNumber_AsSsize_t(PyObject *o, PyObject *exc)¶ Возвращает o преобразованное в Py_ssize_t значение, если o интерпретируется как целое число. Если вызов завершается неуспешно, возникает исключение и
-1возвращенный.Если o можно преобразовать в Python int, но попытка преобразовать в Py_ssize_t значение поднимает
OverflowError, то аргумент exc - это тип создаваемого исключения (обычноIndexErrorилиOverflowError). Если exc равноNULL, то исключение очищается, и значение обрезаетсяPY_SSIZE_T_MINдля отрицательного целого числа илиPY_SSIZE_T_MAXположительного целого числа.
