Утиліти операційної системи¶
-
PyObject *PyOS_FSPath(PyObject *path)¶
- Return value: New reference. Part of the Stable ABI since version 3.6.
Return the file system representation for path. If the object is a
str
orbytes
object, then a new strong reference is returned. If the object implements theos.PathLike
interface, then__fspath__()
is returned as long as it is astr
orbytes
object. OtherwiseTypeError
is raised andNULL
is returned.Нове в версії 3.6.
-
int Py_FdIsInteractive(FILE *fp, const char *filename)¶
Return true (nonzero) if the standard I/O file fp with name filename is deemed interactive. This is the case for files for which
isatty(fileno(fp))
is true. If the global flagPy_InteractiveFlag
is true, this function also returns true if the filename pointer isNULL
or if the name is equal to one of the strings'<stdin>'
or'???'
.
-
void PyOS_BeforeFork()¶
- Part of the Stable ABI on platforms with fork() since version 3.7.
Функція для підготовки деякого внутрішнього стану перед розгалуженням процесу. Це слід викликати перед викликом
fork()
або будь-якої подібної функції, яка клонує поточний процес. Доступно лише в системах, де визначеноfork()
.Попередження
Виклик C
fork()
має здійснюватися лише з «main» потоку (з «main» інтерпретатора). Те саме стосуєтьсяPyOS_BeforeFork()
.Нове в версії 3.7.
-
void PyOS_AfterFork_Parent()¶
- Part of the Stable ABI on platforms with fork() since version 3.7.
Функція для оновлення деякого внутрішнього стану після розгалуження процесу. Це слід викликати з батьківського процесу після виклику
fork()
або будь-якої подібної функції, яка клонує поточний процес, незалежно від того, чи клонування процесу було успішним. Доступно лише в системах, де визначеноfork()
.Попередження
Виклик C
fork()
має здійснюватися лише з «main» потоку (з «main» інтерпретатора). Те саме стосуєтьсяPyOS_AfterFork_Parent()
.Нове в версії 3.7.
-
void PyOS_AfterFork_Child()¶
- Part of the Stable ABI on platforms with fork() since version 3.7.
Функція для оновлення стану внутрішнього інтерпретатора після розгалуження процесу. Це має бути викликано з дочірнього процесу після виклику
fork()
або будь-якої подібної функції, яка клонує поточний процес, якщо є шанс, що процес знову викличе інтерпретатор Python. Доступно лише в системах, де визначеноfork()
.Попередження
Виклик C
fork()
має здійснюватися лише з «main» потоку (з «main» інтерпретатора). Те саме стосуєтьсяPyOS_AfterFork_Child()
.Нове в версії 3.7.
Дивись також
os.register_at_fork()
дозволяє реєструвати користувацькі функції Python для викликуPyOS_BeforeFork()
,PyOS_AfterFork_Parent()
іPyOS_AfterFork_Child()
.
-
void PyOS_AfterFork()¶
- Part of the Stable ABI on platforms with fork().
Функція для оновлення деякого внутрішнього стану після розгалуження процесу; це слід викликати в новому процесі, якщо інтерпретатор Python продовжуватиме використовуватися. Якщо новий виконуваний файл завантажується в новий процес, цю функцію не потрібно викликати.
Застаріло починаючи з версії 3.7: Цю функцію замінює
PyOS_AfterFork_Child()
.
-
int PyOS_CheckStack()¶
- Part of the Stable ABI on platforms with USE_STACKCHECK since version 3.7.
Return true when the interpreter runs out of stack space. This is a reliable check, but is only available when
USE_STACKCHECK
is defined (currently on certain versions of Windows using the Microsoft Visual C++ compiler).USE_STACKCHECK
will be defined automatically; you should never change the definition in your own code.
-
typedef void (*PyOS_sighandler_t)(int)¶
- Part of the Stable ABI.
-
PyOS_sighandler_t PyOS_getsig(int i)¶
- Part of the Stable ABI.
Return the current signal handler for signal i. This is a thin wrapper around either
sigaction()
orsignal()
. Do not call those functions directly!
-
PyOS_sighandler_t PyOS_setsig(int i, PyOS_sighandler_t h)¶
- Part of the Stable ABI.
Set the signal handler for signal i to be h; return the old signal handler. This is a thin wrapper around either
sigaction()
orsignal()
. Do not call those functions directly!
-
wchar_t *Py_DecodeLocale(const char *arg, size_t *size)¶
- Part of the Stable ABI since version 3.7.
Попередження
Цю функцію не слід викликати безпосередньо: використовуйте
PyConfig
API з функцієюPyConfig_SetBytesString()
, яка гарантує, що Python попередньо ініціалізовано.Цю функцію не можна викликати до Python попередньо ініціалізовано і щоб локаль LC_CTYPE була правильно налаштована: див. функцію
Py_PreInitialize()
.Декодуйте рядок байтів із filesystem encoding and error handler. Якщо обробником помилок є surrogateescape error handler, недекодовані байти декодуються як символи в діапазоні U+DC80..U+DCFF; і якщо послідовність байтів може бути декодована як сурогатний символ, байти екрануються за допомогою обробника помилок surrogateescape замість їх декодування.
Поверніть вказівник на щойно виділений широкий рядок символів, використовуйте
PyMem_RawFree()
, щоб звільнити пам’ять. Якщо розмір не дорівнюєNULL
, запишіть кількість широких символів, за винятком нульового символу, у*size
Повертає
NULL
у разі помилки декодування або помилки виділення пам’яті. Якщо size не дорівнюєNULL
,*size
встановлюється на(size_t)-1
у разі помилки пам’яті або встановлюється на(size_t)-2
у разі помилки декодування.filesystem encoding and error handler вибираються
PyConfig_Read()
: див. члениfilesystem_encoding
іfilesystem_errors
PyConfig
.Помилки декодування ніколи не повинні траплятися, якщо немає помилки в бібліотеці C.
Використовуйте функцію
Py_EncodeLocale()
, щоб закодувати рядок символів назад у рядок байтів.Дивись також
Функції
PyUnicode_DecodeFSDefaultAndSize()
іPyUnicode_DecodeLocaleAndSize()
.Нове в версії 3.5.
Змінено в версії 3.7: Тепер функція використовує кодування UTF-8 у режимі Python UTF-8 Mode.
Змінено в версії 3.8: The function now uses the UTF-8 encoding on Windows if
Py_LegacyWindowsFSEncodingFlag
is zero;
-
char *Py_EncodeLocale(const wchar_t *text, size_t *error_pos)¶
- Part of the Stable ABI since version 3.7.
Закодуйте широкий рядок символів у filesystem encoding and error handler. Якщо обробником помилок є surrogateescape error handler, сурогатні символи в діапазоні U+DC80..U+DCFF перетворюються на байти 0x80..0xFF.
Поверніть вказівник на щойно виділений рядок байтів, використовуйте
PyMem_Free()
, щоб звільнити пам’ять. ПовертаєNULL
у разі помилки кодування або помилки виділення пам’яті.Якщо error_pos не дорівнює
NULL
,*error_pos
встановлюється на(size_t)-1
у разі успіху або встановлюється на індекс недійсного символу в разі помилки кодування.filesystem encoding and error handler вибираються
PyConfig_Read()
: див. члениfilesystem_encoding
іfilesystem_errors
PyConfig
.Використовуйте функцію
Py_DecodeLocale()
, щоб декодувати рядок байтів назад до широкого рядка символів.Попередження
Цю функцію не можна викликати до Python попередньо ініціалізовано і щоб локаль LC_CTYPE була правильно налаштована: див. функцію
Py_PreInitialize()
.Дивись також
Функції
PyUnicode_EncodeFSDefault()
іPyUnicode_EncodeLocale()
.Нове в версії 3.5.
Змінено в версії 3.7: Тепер функція використовує кодування UTF-8 у режимі Python UTF-8 Mode.
Змінено в версії 3.8: The function now uses the UTF-8 encoding on Windows if
Py_LegacyWindowsFSEncodingFlag
is zero.
Системні функції¶
Це службові функції, які роблять функціональні можливості модуля sys
доступними для коду C. Усі вони працюють із dict модуля sys
поточного потоку інтерпретатора, який міститься у внутрішній структурі стану потоку.
-
PyObject *PySys_GetObject(const char *name)¶
- Return value: Borrowed reference. Part of the Stable ABI.
Повертає ім’я об’єкта з модуля
sys
абоNULL
, якщо він не існує, без встановлення винятку.
-
int PySys_SetObject(const char *name, PyObject *v)¶
- Part of the Stable ABI.
Встановіть name у модулі
sys
на v, якщо v не має значенняNULL
, у цьому випадку name буде видалено з модуля sys. Повертає0
у разі успіху,-1
у разі помилки.
-
void PySys_ResetWarnOptions()¶
- Part of the Stable ABI.
Скинути
sys.warnoptions
до порожнього списку. Цю функцію можна викликати передPy_Initialize()
.
-
void PySys_AddWarnOption(const wchar_t *s)¶
- Part of the Stable ABI.
This API is kept for backward compatibility: setting
PyConfig.warnoptions
should be used instead, see Python Initialization Configuration.Append s to
sys.warnoptions
. This function must be called prior toPy_Initialize()
in order to affect the warnings filter list.Застаріло починаючи з версії 3.11.
-
void PySys_AddWarnOptionUnicode(PyObject *unicode)¶
- Part of the Stable ABI.
This API is kept for backward compatibility: setting
PyConfig.warnoptions
should be used instead, see Python Initialization Configuration.Append unicode to
sys.warnoptions
.Note: this function is not currently usable from outside the CPython implementation, as it must be called prior to the implicit import of
warnings
inPy_Initialize()
to be effective, but can’t be called until enough of the runtime has been initialized to permit the creation of Unicode objects.Застаріло починаючи з версії 3.11.
-
void PySys_SetPath(const wchar_t *path)¶
- Part of the Stable ABI.
This API is kept for backward compatibility: setting
PyConfig.module_search_paths
andPyConfig.module_search_paths_set
should be used instead, see Python Initialization Configuration.Set
sys.path
to a list object of paths found in path which should be a list of paths separated with the platform’s search path delimiter (:
on Unix,;
on Windows).Застаріло починаючи з версії 3.11.
-
void PySys_WriteStdout(const char *format, ...)¶
- Part of the Stable ABI.
Запишіть вихідний рядок, описаний format, у
sys.stdout
. Ніяких винятків не викликається, навіть якщо відбувається скорочення (див. нижче).format має обмежувати загальний розмір відформатованого вихідного рядка до 1000 байтів або менше – після 1000 байтів вихідний рядок скорочується. Зокрема, це означає, що необмежені формати «%s» не повинні відбуватися; їх слід обмежити за допомогою «%. <N> s», де <N> — це десяткове число, обчислене таким чином, що <N> плюс максимальний розмір іншого відформатованого тексту не перевищує 1000 байт. Також слідкуйте за «%f», який може друкувати сотні цифр для дуже великих чисел.
Якщо виникає проблема або
sys.stdout
не налаштовано, форматоване повідомлення записується в реальний (рівень C) stdout.
-
void PySys_WriteStderr(const char *format, ...)¶
- Part of the Stable ABI.
Як
PySys_WriteStdout()
, але натомість записуйте вsys.stderr
або stderr.
-
void PySys_FormatStdout(const char *format, ...)¶
- Part of the Stable ABI.
Функція схожа на PySys_WriteStdout(), але форматує повідомлення за допомогою
PyUnicode_FromFormatV()
і не скорочує повідомлення до довільної довжини.Нове в версії 3.2.
-
void PySys_FormatStderr(const char *format, ...)¶
- Part of the Stable ABI.
Як
PySys_FormatStdout()
, але замість цього записуйте вsys.stderr
або stderr.Нове в версії 3.2.
-
void PySys_AddXOption(const wchar_t *s)¶
- Part of the Stable ABI since version 3.7.
This API is kept for backward compatibility: setting
PyConfig.xoptions
should be used instead, see Python Initialization Configuration.Parse s as a set of
-X
options and add them to the current options mapping as returned byPySys_GetXOptions()
. This function may be called prior toPy_Initialize()
.Нове в версії 3.2.
Застаріло починаючи з версії 3.11.
-
PyObject *PySys_GetXOptions()¶
- Return value: Borrowed reference. Part of the Stable ABI since version 3.7.
Повертає поточний словник параметрів
-X
, подібно доsys._xoptions
. У разі помилки повертаєтьсяNULL
і встановлюється виняток.Нове в версії 3.2.
-
int PySys_Audit(const char *event, const char *format, ...)¶
Викликати подію аудиту з будь-якими активними хуками. Повертає нуль у разі успіху та відмінний від нуля з винятком, встановленим у випадку невдачі.
If any hooks have been added, format and other arguments will be used to construct a tuple to pass. Apart from
N
, the same format characters as used inPy_BuildValue()
are available. If the built value is not a tuple, it will be added into a single-element tuple. (TheN
format option consumes a reference, but since there is no way to know whether arguments to this function will be consumed, using it may cause reference leaks.)Зауважте, що символи формату
#
завжди слід розглядати якPy_ssize_t
, незалежно від того, чи було визначеноPY_SSIZE_T_CLEAN
.sys.audit()
виконує ту саму функцію з коду Python.Нове в версії 3.8.
Змінено в версії 3.8.2: Вимагати
Py_ssize_t
для символів формату#
. Раніше виникало неминуче попередження про застарілу версію.
-
int PySys_AddAuditHook(Py_AuditHookFunction hook, void *userData)¶
Додайте хук, який можна викликати, до списку активних хуків аудиту. Повертає нуль у разі успіху та ненуль у разі невдачі. Якщо середовище виконання було ініціалізовано, також установіть помилку в разі помилки. Хуки, додані через цей API, викликаються для всіх інтерпретаторів, створених середовищем виконання.
Покажчик userData передається в функцію-перехоплювач. Оскільки функції підключення можуть викликатися з різних середовищ виконання, цей вказівник не повинен посилатися безпосередньо на стан Python.
Цю функцію безпечно викликати перед
Py_Initialize()
. Під час виклику після ініціалізації середовища виконання наявні перехоплювачі аудиту отримують сповіщення та можуть мовчки перервати операцію, викликавши помилку підкласу зException
(інші помилки не будуть заглушені).The hook function is always called with the GIL held by the Python interpreter that raised the event.
Дивіться PEP 578 для детального опису аудиту. Функції середовища виконання та стандартної бібліотеки, які викликають події, перераховані в таблиці подій аудиту. Подробиці наведено в документації кожної функції.
If the interpreter is initialized, this function raises an auditing event
sys.addaudithook
with no arguments. If any existing hooks raise an exception derived fromException
, the new hook will not be added and the exception is cleared. As a result, callers cannot assume that their hook has been added unless they control all existing hooks.-
typedef int (*Py_AuditHookFunction)(const char *event, PyObject *args, void *userData)¶
The type of the hook function. event is the C string event argument passed to
PySys_Audit()
. args is guaranteed to be aPyTupleObject
. userData is the argument passed to PySys_AddAuditHook().
Нове в версії 3.8.
-
typedef int (*Py_AuditHookFunction)(const char *event, PyObject *args, void *userData)¶
Контроль процесів¶
-
void Py_FatalError(const char *message)¶
- Part of the Stable ABI.
Print a fatal error message and kill the process. No cleanup is performed. This function should only be invoked when a condition is detected that would make it dangerous to continue using the Python interpreter; e.g., when the object administration appears to be corrupted. On Unix, the standard C library function
abort()
is called which will attempt to produce acore
file.Функцію
Py_FatalError()
замінено макросом, який автоматично реєструє назву поточної функції, якщо не визначено макросPy_LIMITED_API
.Змінено в версії 3.9: Автоматично реєструйте назву функції.
-
void Py_Exit(int status)¶
- Part of the Stable ABI.
Вийти з поточного процесу. Це викликає
Py_FinalizeEx()
, а потім викликає стандартну функцію бібліотеки Cexit(status)
. ЯкщоPy_FinalizeEx()
вказує на помилку, статус виходу встановлюється на 120.Змінено в версії 3.6: Помилки під час фіналізації більше не ігноруються.
-
int Py_AtExit(void (*func)())¶
- Part of the Stable ABI.
Зареєструйте функцію очищення, яку буде викликати
Py_FinalizeEx()
. Функція очищення буде викликана без аргументів і не повинна повертати значення. Можна зареєструвати щонайбільше 32 функції очищення. Після успішної реєстраціїPy_AtExit()
повертає0
; у разі помилки повертає-1
. Першою викликається функція очищення, зареєстрована останньою. Кожна функція очищення буде викликана щонайбільше один раз. Оскільки внутрішня фіналізація Python буде завершена до виконання функції очищення, жодні API Python не повинні викликатися за допомогою func.