Версионирование API и ABI¶
CPython отображает номер своей версии в следующих макросах. Обратите внимание, что они соответствуют версии, с которой код собирается, а не обязательно версии, используемой во время выполнения.
Обсуждение стабильности API и ABI в разных версиях см. в C Стабильность API.
-
PY_MAJOR_VERSION¶
3
в3.4.1a2
.
-
PY_MINOR_VERSION¶
4
в3.4.1a2
.
-
PY_MICRO_VERSION¶
1
в3.4.1a2
.
-
PY_RELEASE_LEVEL¶
Значение
a
в3.4.1a2
. Это может быть0xA
для альфы,0xB
для беты,0xC
для релиз-кандидата или0xF
для финальной версии.
-
PY_RELEASE_SERIAL¶
2
в3.4.1a2
. Ноль для финальных релизов.
-
PY_VERSION_HEX¶
Номер версии Python, закодированный в виде одного целого числа.
Информацию о версии можно найти, рассматривая ее как 32-битное число следующим образом:
Байты
Биты (порядок большой эндин)
Значение
Значение для
3.4.1a2
1
1-8
PY_MAJOR_VERSION
0x03
2
9-16
PY_MINOR_VERSION
0x04
3
17-24
PY_MICRO_VERSION
0x01
4
25-28
PY_RELEASE_LEVEL
0xA
29-32
PY_RELEASE_SERIAL
0x2
Таким образом,
3.4.1a2
является гексверсией0x030401a2
, а3.10.0
- гексверсией0x030a00f0
.Используйте его для числовых сравнений, например
#if PY_VERSION_HEX >= ...
.Эта версия также доступна через символ
Py_Version
.
-
const unsigned long Py_Version¶
- Часть Стабильный ABI с версии 3.11.
Номер версии Python во время выполнения, закодированный в виде одного постоянного целого числа, в том же формате, что и макрос
PY_VERSION_HEX
. Он содержит версию Python, используемую во время выполнения.Added in version 3.11.
Все приведенные макросы определены в Include/patchlevel.h.