Утиліти операційної системи¶
-
PyObject*
PyOS_FSPath
(PyObject *path)¶ - Return value: New reference.
Return the file system representation for path. If the object is a
str
orbytes
object, then its reference count is incremented. 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
()¶ Функція для підготовки деякого внутрішнього стану перед розгалуженням процесу. Це слід викликати перед викликом
fork()
або будь-якої подібної функції, яка клонує поточний процес. Доступно лише в системах, де визначеноfork()
.Попередження
Виклик C
fork()
має здійснюватися лише з «main» потоку (з «main» інтерпретатора). Те саме стосуєтьсяPyOS_BeforeFork()
.Нове в версії 3.7.
-
void
PyOS_AfterFork_Parent
()¶ Функція для оновлення деякого внутрішнього стану після розгалуження процесу. Це слід викликати з батьківського процесу після виклику
fork()
або будь-якої подібної функції, яка клонує поточний процес, незалежно від того, чи клонування процесу було успішним. Доступно лише в системах, де визначеноfork()
.Попередження
Виклик C
fork()
має здійснюватися лише з «main» потоку (з «main» інтерпретатора). Те саме стосуєтьсяPyOS_AfterFork_Parent()
.Нове в версії 3.7.
-
void
PyOS_AfterFork_Child
()¶ Функція для оновлення стану внутрішнього інтерпретатора після розгалуження процесу. Це має бути викликано з дочірнього процесу після виклику
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
()¶ Функція для оновлення деякого внутрішнього стану після розгалуження процесу; це слід викликати в новому процесі, якщо інтерпретатор Python продовжуватиме використовуватися. Якщо новий виконуваний файл завантажується в новий процес, цю функцію не потрібно викликати.
Застаріло починаючи з версії 3.7: Цю функцію замінює
PyOS_AfterFork_Child()
.
-
int
PyOS_CheckStack
()¶ 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 Windows using the Microsoft Visual C++ compiler).USE_STACKCHECK
will be defined automatically; you should never change the definition in your own code.
-
PyOS_sighandler_t
PyOS_getsig
(int i)¶ 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
is a typedef alias forvoid (*)(int)
.
-
PyOS_sighandler_t
PyOS_setsig
(int i, PyOS_sighandler_t h)¶ 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!PyOS_sighandler_t
is a typedef alias forvoid (*)(int)
.
-
wchar_t*
Py_DecodeLocale
(const char* arg, size_t *size)¶ Decode a byte string from the locale encoding with the surrogateescape error handler: undecodable bytes are decoded as characters in range U+DC80..U+DCFF. If a byte sequence can be decoded as a surrogate character, escape the bytes using the surrogateescape error handler instead of decoding them.
Encoding, highest priority to lowest priority:
UTF-8
on macOS, Android, and VxWorks;UTF-8
on Windows ifPy_LegacyWindowsFSEncodingFlag
is zero;UTF-8
if the Python UTF-8 mode is enabled;ASCII
if theLC_CTYPE
locale is"C"
,nl_langinfo(CODESET)
returns theASCII
encoding (or an alias), andmbstowcs()
andwcstombs()
functions uses theISO-8859-1
encoding.the current locale encoding.
Поверніть вказівник на щойно виділений широкий рядок символів, використовуйте
PyMem_RawFree()
, щоб звільнити пам’ять. Якщо розмір не дорівнюєNULL
, запишіть кількість широких символів, за винятком нульового символу, у*size
Повертає
NULL
у разі помилки декодування або помилки виділення пам’яті. Якщо size не дорівнюєNULL
,*size
встановлюється на(size_t)-1
у разі помилки пам’яті або встановлюється на(size_t)-2
у разі помилки декодування.Помилки декодування ніколи не повинні траплятися, якщо немає помилки в бібліотеці C.
Використовуйте функцію
Py_EncodeLocale()
, щоб закодувати рядок символів назад у рядок байтів.Дивись також
Функції
PyUnicode_DecodeFSDefaultAndSize()
іPyUnicode_DecodeLocaleAndSize()
.Нове в версії 3.5.
Змінено в версії 3.7: The function now uses the UTF-8 encoding in the 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)¶ Encode a wide character string to the locale encoding with the surrogateescape error handler: surrogate characters in the range U+DC80..U+DCFF are converted to bytes 0x80..0xFF.
Encoding, highest priority to lowest priority:
UTF-8
on macOS, Android, and VxWorks;UTF-8
on Windows ifPy_LegacyWindowsFSEncodingFlag
is zero;UTF-8
if the Python UTF-8 mode is enabled;ASCII
if theLC_CTYPE
locale is"C"
,nl_langinfo(CODESET)
returns theASCII
encoding (or an alias), andmbstowcs()
andwcstombs()
functions uses theISO-8859-1
encoding.the current locale encoding.
The function uses the UTF-8 encoding in the Python UTF-8 mode.
Поверніть вказівник на щойно виділений рядок байтів, використовуйте
PyMem_Free()
, щоб звільнити пам’ять. ПовертаєNULL
у разі помилки кодування або помилки виділення пам’яті.Якщо error_pos не дорівнює
NULL
,*error_pos
встановлюється на(size_t)-1
у разі успіху або встановлюється на індекс недійсного символу в разі помилки кодування.Використовуйте функцію
Py_DecodeLocale()
, щоб декодувати рядок байтів назад до широкого рядка символів.Дивись також
Функції
PyUnicode_EncodeFSDefault()
іPyUnicode_EncodeLocale()
.Нове в версії 3.5.
Змінено в версії 3.7: The function now uses the UTF-8 encoding in the 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.
Повертає ім’я об’єкта з модуля
sys
абоNULL
, якщо він не існує, без встановлення винятку.
-
int
PySys_SetObject
(const char *name, PyObject *v)¶ Встановіть name у модулі
sys
на v, якщо v не має значенняNULL
, у цьому випадку name буде видалено з модуля sys. Повертає0
у разі успіху,-1
у разі помилки.
-
void
PySys_ResetWarnOptions
()¶ Скинути
sys.warnoptions
до порожнього списку. Цю функцію можна викликати передPy_Initialize()
.
-
void
PySys_AddWarnOption
(const wchar_t *s)¶ Append s to
sys.warnoptions
. This function must be called prior toPy_Initialize()
in order to affect the warnings filter list.
-
void
PySys_AddWarnOptionUnicode
(PyObject *unicode)¶ 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.
-
void
PySys_SetPath
(const wchar_t *path)¶ 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).
-
void
PySys_WriteStdout
(const char *format, ...)¶ Запишіть вихідний рядок, описаний format, у
sys.stdout
. Ніяких винятків не викликається, навіть якщо відбувається скорочення (див. нижче).format має обмежувати загальний розмір відформатованого вихідного рядка до 1000 байтів або менше – після 1000 байтів вихідний рядок скорочується. Зокрема, це означає, що необмежені формати «%s» не повинні відбуватися; їх слід обмежити за допомогою «%. <N> s», де <N> — це десяткове число, обчислене таким чином, що <N> плюс максимальний розмір іншого відформатованого тексту не перевищує 1000 байт. Також слідкуйте за «%f», який може друкувати сотні цифр для дуже великих чисел.
Якщо виникає проблема або
sys.stdout
не налаштовано, форматоване повідомлення записується в реальний (рівень C) stdout.
-
void
PySys_WriteStderr
(const char *format, ...)¶ Як
PySys_WriteStdout()
, але натомість записуйте вsys.stderr
або stderr.
-
void
PySys_FormatStdout
(const char *format, ...)¶ Функція схожа на PySys_WriteStdout(), але форматує повідомлення за допомогою
PyUnicode_FromFormatV()
і не скорочує повідомлення до довільної довжини.Нове в версії 3.2.
-
void
PySys_FormatStderr
(const char *format, ...)¶ Як
PySys_FormatStdout()
, але замість цього записуйте вsys.stderr
або stderr.Нове в версії 3.2.
-
void
PySys_AddXOption
(const wchar_t *s)¶ 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.
-
PyObject *
PySys_GetXOptions
()¶ - Return value: Borrowed reference.
Повертає поточний словник параметрів
-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 of type
int (*)(const char *event, PyObject *args, void *userData)
, where args is guaranteed to be aPyTupleObject
. 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 a 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.Нове в версії 3.8.
Контроль процесів¶
-
void
Py_FatalError
(const char *message)¶ 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)¶ Вийти з поточного процесу. Це викликає
Py_FinalizeEx()
, а потім викликає стандартну функцію бібліотеки Cexit(status)
. ЯкщоPy_FinalizeEx()
вказує на помилку, статус виходу встановлюється на 120.Змінено в версії 3.6: Помилки під час фіналізації більше не ігноруються.
-
int
Py_AtExit
(void (*func)())¶ Зареєструйте функцію очищення, яку буде викликати
Py_FinalizeEx()
. Функція очищення буде викликана без аргументів і не повинна повертати значення. Можна зареєструвати щонайбільше 32 функції очищення. Після успішної реєстраціїPy_AtExit()
повертає0
; у разі помилки повертає-1
. Першою викликається функція очищення, зареєстрована останньою. Кожна функція очищення буде викликана щонайбільше один раз. Оскільки внутрішня фіналізація Python буде завершена до виконання функції очищення, жодні API Python не повинні викликатися за допомогою func.