Протокол нумерации¶
-
int PyNumber_Check(PyObject *o)¶
- Part of the Стабильный ABI.
Возвращает
1, если объект o предоставляет числовые протоколы, и значение false в противном случае. Эта функция всегда выполняется успешно.Изменено в версии 3.8: Возвращает
1, если o является целым индексом.
-
PyObject *PyNumber_Add(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат добавления o1 и o2 или
NULLв случае сбоя. Это эквивалент выражения Pythono1 + o2.
-
PyObject *PyNumber_Subtract(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат вычитания o2 из o1 или
NULLв случае сбоя. Это эквивалент выражения Pythono1 - o2.
-
PyObject *PyNumber_Multiply(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат умножения o1 и o2 или
NULLв случае сбоя. Это эквивалент выражения Pythono1 * o2.
-
PyObject *PyNumber_MatrixMultiply(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI since version 3.7.
Возвращает результат умножения матрицы на o1 и o2 или
NULLв случае сбоя. Это эквивалент выражения Pythono1 @ o2.Добавлено в версии 3.5.
-
PyObject *PyNumber_FloorDivide(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает значение o1, разделенное на o2, или
NULLв случае сбоя. Это эквивалент выражения Pythono1 // o2.
-
PyObject *PyNumber_TrueDivide(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает приемлемое приближение математического значения o1, деленного на o2, или
NULLв случае сбоя. Возвращаемое значение является «приблизительным», поскольку двоичные числа с плавающей запятой являются приблизительными; невозможно представить все действительные числа с основанием два. Эта функция может возвращать значение с плавающей запятой при передаче двух целых чисел. Это эквивалент выражения Pythono1 / o2.
-
PyObject *PyNumber_Remainder(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает остаток от деления o1 на o2 или
NULLв случае сбоя. Это эквивалент выражения Pythono1 % o2.
-
PyObject *PyNumber_Divmod(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Смотрите встроенную функцию
divmod(). При сбое возвращаетNULL. Это эквивалент выражения Pythondivmod(o1, o2).
-
PyObject *PyNumber_Power(PyObject *o1, PyObject *o2, PyObject *o3)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Смотрите встроенную функцию
pow(). При сбое возвращаетNULL. Это эквивалент выражения Pythonpow(o1, o2, o3), где o3 необязательно. Если o3 следует игнорировать, передайте вместо негоPy_None(передачаNULLдля o3 приведет к незаконному доступу к памяти).
-
PyObject *PyNumber_Negative(PyObject *o)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает значение o в случае успеха или
NULLв случае неудачи. Это эквивалент выражения Python-o.
-
PyObject *PyNumber_Positive(PyObject *o)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает o в случае успеха или
NULLв случае неудачи. Это эквивалент выражения Python+o.
-
PyObject *PyNumber_Absolute(PyObject *o)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает абсолютное значение o или
NULLв случае сбоя. Это эквивалент выражения Pythonabs(o).
-
PyObject *PyNumber_Invert(PyObject *o)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает побитовое отрицание o в случае успеха или
NULLв случае неудачи. Это эквивалент выражения Python~o.
-
PyObject *PyNumber_Lshift(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат сдвига влево o1 на o2 в случае успеха или
NULLв случае неудачи. Это эквивалент выражения Pythono1 << o2.
-
PyObject *PyNumber_Rshift(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат сдвига вправо o1 на o2 в случае успеха или
NULLв случае неудачи. Это эквивалент выражения Pythono1 >> o2.
-
PyObject *PyNumber_And(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает «побитовое и» из o1 и o2 в случае успеха и
NULLв случае неудачи. Это эквивалент выражения Pythono1 & o2.
-
PyObject *PyNumber_Xor(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает «побитовое исключающее or» из o1 на o2 в случае успеха или
NULLв случае сбоя. Это эквивалент выражения Pythono1 ^ o2.
-
PyObject *PyNumber_Or(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает «побитовое или» из o1 и o2 в случае успеха или
NULLв случае неудачи. Это эквивалент выражения Pythono1 | o2.
-
PyObject *PyNumber_InPlaceAdd(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат добавления o1 и o2 или
NULLв случае сбоя. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 += o2.
-
PyObject *PyNumber_InPlaceSubtract(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат вычитания o2 из o1 или
NULLв случае сбоя. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 -= o2.
-
PyObject *PyNumber_InPlaceMultiply(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат умножения o1 и o2 или
NULLв случае сбоя. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 *= o2.
-
PyObject *PyNumber_InPlaceMatrixMultiply(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI since version 3.7.
Возвращает результат умножения матрицы на o1 и o2 или
NULLв случае сбоя. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 @= o2.Добавлено в версии 3.5.
-
PyObject *PyNumber_InPlaceFloorDivide(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает математическое значение деления o1 на o2 или
NULLв случае сбоя. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 //= o2.
-
PyObject *PyNumber_InPlaceTrueDivide(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает приемлемое приближение математического значения o1, деленного на o2, или
NULLв случае сбоя. Возвращаемое значение является «приблизительным», поскольку двоичные числа с плавающей запятой являются приблизительными; невозможно представить все действительные числа с основанием два. Эта функция может возвращать значение с плавающей запятой при передаче двух целых чисел. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 /= o2.
-
PyObject *PyNumber_InPlaceRemainder(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает остаток от деления o1 на o2 или
NULLв случае сбоя. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 %= o2.
-
PyObject *PyNumber_InPlacePower(PyObject *o1, PyObject *o2, PyObject *o3)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Смотрите встроенную функцию
pow(). При сбое возвращаетNULL. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 **= o2, когда значение o3 равноPy_None, или вариант на местеpow(o1, o2, o3)в противном случае. Если o3 следует игнорировать, передайте вместо негоPy_None(передачаNULLдля o3 приведет к незаконному доступу к памяти).
-
PyObject *PyNumber_InPlaceLshift(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат сдвига влево o1 на o2 в случае успеха или
NULLв случае неудачи. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 <<= o2.
-
PyObject *PyNumber_InPlaceRshift(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает результат сдвига вправо o1 на o2 в случае успеха или
NULLв случае неудачи. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 >>= o2.
-
PyObject *PyNumber_InPlaceAnd(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает «побитовое и» из o1 и o2 в случае успеха и
NULLв случае сбоя. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 &= o2.
-
PyObject *PyNumber_InPlaceXor(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает «побитовое исключающее или» для o1 с помощью o2 в случае успеха или
NULLв случае сбоя. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 ^= o2.
-
PyObject *PyNumber_InPlaceOr(PyObject *o1, PyObject *o2)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает «побитовое или» из o1 и o2 в случае успеха или
NULLв случае сбоя. Операция выполняется на месте, если o1 поддерживает ее. Это эквивалент инструкции Pythono1 |= o2.
-
PyObject *PyNumber_Long(PyObject *o)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает значение o, преобразованное в целочисленный объект, в случае успеха или
NULLв случае неудачи. Это эквивалент выражения Pythonint(o).
-
PyObject *PyNumber_Float(PyObject *o)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает значение o, преобразованное в объект с плавающей точкой, в случае успеха или
NULLв случае неудачи. Это эквивалент выражения Pythonfloat(o).
-
PyObject *PyNumber_Index(PyObject *o)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает значение o, преобразованное в Python int, в случае успеха или
NULLс исключениемTypeError, возникающим при сбое.Изменено в версии 3.10: Результат всегда имеет точный тип
int. Ранее результатом мог быть экземпляр подклассаint.
-
PyObject *PyNumber_ToBase(PyObject *n, int base)¶
- Возвращаемое значение: Новая ссылка. Part of the Стабильный ABI.
Возвращает целое число n, преобразованное в базовое значение base, в виде строки. Аргумент base должен быть одним из 2, 8, 10 или 16. Для значений по основанию 2, 8 или 16 возвращаемая строка имеет префикс в виде базового маркера
'0b','0o', или'0x'соответственно. Если n не является значением int в Python, оно сначала преобразуется с помощьюPyNumber_Index().
-
Py_ssize_t PyNumber_AsSsize_t(PyObject *o, PyObject *exc)¶
- Part of the Стабильный ABI.
Возвращает значение o, преобразованное в значение a
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для положительного целого числа.
-
int PyIndex_Check(PyObject *o)¶
- Part of the Стабильный ABI since version 3.8.
Возвращает
1, если o является целым индексом (заполненnb_indexв структуреtp_as_number), и0в противном случае. Эта функция всегда выполняется успешно.