- Python 3: Get and Check Exit Status Code (Return Code) from subprocess.run()
- Check Exit Status Code and Raise Error if Non-Zero
- Manual Check
- check=True Option (Shorter Code)
- Как использовать функцию exit в скриптах Python
- Как использовать функцию exit() в Python
- Пояснение кода
- Best practices использования функции exit в Python
- Импортируйте модуль sys
- Определите условие выхода
- Используйте sys.exit() для завершения программы
- Очистка ресурсов (опционально)
- Документируйте условия выхода
- Заключение
- Process Exit Codes in Python
- Need Process Exit Codes
- How to Use Exit Codes in Python
- How to Set an Exit Code
Python 3: Get and Check Exit Status Code (Return Code) from subprocess.run()
When running a command using subprocess.run() , the exit status code of the command is available as the .returncode property in the CompletedProcess object returned by run() :
from subprocess import run p = run( [ 'echo', 'Hello, world!' ] ) print( 'exit status code:', p.returncode )
Check Exit Status Code and Raise Error if Non-Zero
Manual Check
If we want our script to stop running and raise an error if the subprocess returns a non-zero exit status code, we could manually check the returncode property of the CompletedProcess object that run() returns:
from subprocess import run print( 'Running command. ' ) p = run( [ 'cat', '/foo' ] ) if p.returncode != 0: raise Exception( f'Invalid result: < p.returncode >' ) # If `cat /foo` fails above, we won't get here. print( 'All done!' )
check=True Option (Shorter Code)
But the shorter way to accomplish the same thing is to just set check=True when we call run() :
from subprocess import run print( 'Running command. ' ) run( [ 'cat', '/foo' ], check=True ) # If `cat /foo` fails above, we won't get here. print( 'All done!' )
Assuming we don’t have a file /foo on our system, cat /foo will return a non-zero exit status code. If we run the code above on a Linux-based system, we’ll see output like this:
Running command. cat: /foo: No such file or directory Traceback (most recent call last): File "test.py", line 4, in run( [ 'cat', '/foo' ], check=True ) File "/usr/lib/python3.8/subprocess.py", line 512, in run raise CalledProcessError(retcode, process.args, subprocess.CalledProcessError: Command '['cat', '/foo']' returned non-zero exit status 1.
Note that All Done! is never printed because the script raised an error before it got to line 5.
If we omit the check=True option:
from subprocess import run print( 'Running command. ' ) run( [ 'cat', '/foo' ] ) # Even if `cat /foo` fails above, we will always get here. print( 'All done!' )
check defaults to False , so we won’t see an error message, and we will see the All done! line:
Running command. cat: /foo: No such file or directory All done!
Как использовать функцию exit в скриптах Python
Функция exit в Python позволяет в любой момент остановить выполнение скрипта или программы. Это может понадобиться для обработки ошибок, тестирования и отладки, остановки программы при соблюдении каких-то условий.
Необязательный аргумент status представляет собой статус выхода. Это целочисленное значение, которое указывает на причину завершения программы. Принято считать, что статус 0 означает успешное выполнение, а любой ненулевой статус указывает на ошибку или ненормальное завершение.
Если аргумент status не указан, используется значение по умолчанию 0.
Вот пример использования функции exit в Python:
print("Before exit") exit(1) print("After exit") # This line will not be executed
В этом примере программа выводит строку «Before exit». Но когда exit() вызывается с аргументом 1, программа немедленно завершается, не выполняя оставшийся код. Поэтому строка «After exit» не выводится.
От редакции Pythonist: также предлагаем почитать статьи «Как запустить скрипт Python» и «Создание Python-скрипта, выполняемого в Unix».
Как использовать функцию exit() в Python
Давайте напишем скрипт на Python и используем в нем функцию exit.
import sys def main(): try: print("Welcome to the program!") # Check for termination condition user_input = input("Do you want to exit the program? (y/n): ") if user_input.lower() == "y": exit_program() # Continue with other operations except Exception as e: print(f"An error occurred: ") exit_program() def exit_program(): print("Exiting the program. ") sys.exit(0) if __name__ == "__main__": main()
Пояснение кода
- Скрипт начинается с импорта модуля sys, который предоставляет доступ к функции exit() .
- Функция main() служит точкой входа в программу. Внутри этой функции можно добавлять свой код.
- Внутри функции main() можно выполнять различные операции. В данном примере мы просто выводим приветственное сообщение и спрашиваем пользователя, хочет ли он выйти.
- После получения пользовательского ввода мы проверяем, хочет ли пользователь выйти. Для этого сравниваем его ввод с «y» (без учета регистра). Если условие истинно, вызываем функцию exit_program() для завершения работы скрипта.
- Функция exit_program() выводит сообщение о том, что программа завершается, а затем вызывает sys.exit(0) для завершения программы. Аргумент 0, переданный в sys.exit() , означает успешное завершение программы. При необходимости вы можете выбрать другой код завершения.
- Наконец, при помощи переменной __name__ проверяем, выполняется ли скрипт как главный модуль. Если это так, вызываем функцию main() для запуска программы.
Best practices использования функции exit в Python
Импортируйте модуль sys
Чтобы использовать функцию exit(), необходимо импортировать модуль sys в начале скрипта. Включите в свой код следующую строку:
Определите условие выхода
Определите условие или ситуацию, в которой вы хотите завершить работу программы. Оно может быть основано на вводе пользователя, определенном событии, состоянии ошибки или любых других критериях, требующих остановки программы.
Используйте sys.exit() для завершения программы
Если условие завершения истинно, вызовите функцию sys.exit() , чтобы остановить выполнение программы. В качестве аргумента ей можно передать необязательный код состояния выхода, указывающий на причину завершения.
Опять же, код состояния 0 обычно используется для обозначения успешного завершения программы, в то время как ненулевые значения представляют различные типы ошибок или исключительных условий.
if condition_met: sys.exit() # Terminate the program with status code 0
Вы также можете передать код состояния для предоставления дополнительной информации:
if error_occurred: sys.exit(1) # Terminate the program with status code 1 indicating an error
Очистка ресурсов (опционально)
Допустим, ваша программа использует ресурсы, которые должны быть надлежащим образом освобождены перед завершением. Примеры — закрытие файлов или освобождение сетевых соединений. В таком случае перед вызовом sys.exit() можно включить код очистки. Это гарантирует, что ресурсы будут обработаны должным образом, даже если программа завершится неожиданно.
Документируйте условия выхода
Важно документировать конкретные условия завершения в коде и оставлять комментарии, указывающие, почему программа завершается. Это поможет другим разработчикам понять цель и поведение вызовов exit() .
Заключение
Теперь вы знаете, как использовать функцию exit в Python для завершения выполнения программы. По желанию можно передать в эту функцию в качестве аргумента код состояния, предоставляя дополнительную информацию о причине завершения.
Соблюдая правила, приведенные в этой статье, вы сможете эффективно использовать exit() для остановки программы в случае необходимости.
Очень важно проявлять осторожность и применять эту функцию разумно. Она должна использоваться только в соответствующих обстоятельствах, когда вы хотите принудительно остановить выполнение вашего скрипта Python при определенных условиях или когда вам нужно завершить программу немедленно.
Process Exit Codes in Python
You can set an exit code for a process via sys.exit() and retrieve the exit code via the exitcode attribute on the multiprocessing.Process class.
In this tutorial you will discover how to get and set exit codes for processes in Python.
Need Process Exit Codes
A process is a running instance of a computer program.
Every Python program is executed in a Process, which is a new instance of the Python interpreter. This process has the name MainProcess and has one thread used to execute the program instructions called the MainThread. Both processes and threads are created and managed by the underlying operating system.
Sometimes we may need to create new child processes in our program in order to execute code concurrently.
Python provides the ability to create and manage new processes via the multiprocessing.Process class.
In multiprocessing, we may need to report the success or failure of a task executed by a child process to other processes.
This can be achieved using exit codes.
What are exit codes and how can we use them between processes in Python?
Run your loops using all CPUs, download my FREE book to learn how.
How to Use Exit Codes in Python
An exit code or exit status is a way for one process to share with another whether it is finished and if so whether it finished successfully or not.
The exit status of a process in computer programming is a small number passed from a child process (or callee) to a parent process (or caller) when it has finished executing a specific procedure or delegated task.
— Exit status, Wikipedia.
An exit code is typically an integer value to represent success or failure of the process, but may also have an associated string message.
Let’s take a closer look at how we might set an exit code in a process and how another process might check the exit code of a process.
How to Set an Exit Code
A process can set the exit code automatically or explicitly.
For example, if the process exits normally, the exit code will be set to zero. If the process terminated with an error or exception, the exit code will be set to one.
A process can also set its exit code when explicitly exiting.
This can be achieved by calling the sys.exit() function and passing the exit code as an argument.
The sys.exit() function will raise a SystemExit exception in the current process, which will terminate the process.
The optional argument arg can be an integer giving the exit status (defaulting to zero), or another type of object.
— sys — System-specific parameters and functions
This function must be called in the main thread of the process and assumes that the SystemExit exception is not handled.
An argument value of 0 indicates a successful exit.