- Обработка исключений Python — блок Try/Except, блок Finally
- 2. Обработка исключений в Python
- 3. Блоки try/except
- a. Несколько except в Python
- b. Несколько исключений в одном except
- c. Общий except после всех блоков except
- 4. Блок finally в Python
- 5. Ключевое слово raise в Python
- a. Raise без определенного исключения в Python
- b. Raise с аргументом в Python
- 6. assert в Python
- a. Второй аргумент для assert
- 7. Объявление собственных исключений Python
- 8. Вывод: обработка исключений Python
- Python ValueError Exception Handling Examples
- 1. What is Python ValueError?
- 2. ValueError Example
- 3. Handling ValueError Exception
- 4. Raising ValueError in a function
- 5. References
Обработка исключений Python — блок Try/Except, блок Finally
В этом материале речь пойдет о блоках try/except , finally и raise . Вместе с тем будет рассмотрено, как создавать собственные исключения в Python.
2. Обработка исключений в Python
Рассмотрим разные типы исключений в Python, которые появляются при срабатывании исключения в коде Python.
3. Блоки try/except
Если код может привести к исключению, его лучше заключить в блок try . Рассмотрим на примере.
try: for i in range(3): print(3/i) except: print("Деление на 0") print("Исключение было обработано")
Программа вывела сообщение, потому что было обработано исключение.
Следом идет блок except . Если не определить тип исключения, то он будет перехватывать любые. Другими словами, это общий обработчик исключений.
Если код в блоке try приводит к исключению, интерпретатор ищет блок except , который указан следом. Оставшаяся часть кода в try исполнена не будет.
Исключения Python особенно полезны, если программа работает с вводом пользователя, ведь никогда нельзя знать, что он может ввести.
a. Несколько except в Python
У одного блока try может быть несколько блоков except . Рассмотрим примеры с несколькими вариантами обработки.
a, b = 1, 0 try: print(a/b) print("Это не будет напечатано") print('10'+10) except TypeError: print("Вы сложили значения несовместимых типов") except ZeroDivisionError: print("Деление на 0")
Когда интерпретатор обнаруживает исключение, он проверяет блоки except соответствующего блока try . В них может быть объявлено, какие типы исключений они обрабатывают. Если интерпретатор находит соответствующее исключение, он исполняет этот блок except .
В первом примере первая инструкция приводит к ZeroDivisionError . Эта ошибка обрабатывается в блоке except , но инструкции в try после первой не исполняются. Так происходит из-за того, что после первого исключения дальнейшие инструкции просто пропускаются. И если подходящий или общий блоки except не удается найти, исключение не обрабатывается. В таком случае оставшаяся часть программы не будет запущена. Но если обработать исключение, то код после блоков except и finally исполнится. Попробуем.
a, b = 1, 0 try: print(a/b) except: print("Вы не можете разделить на 0") print("Будет ли это напечатано?")
Вы не можете разделить на 0 Будет ли это напечатано?
b. Несколько исключений в одном except
Можно использовать один блок except для обработки нескольких исключений. Для этого используются скобки. Без них интерпретатор вернет синтаксическую ошибку.
try: print('10'+10) print(1/0) except (TypeError,ZeroDivisionError): print("Неверный ввод")
c. Общий except после всех блоков except
В конце концов, завершить все отдельные блоки except можно одним общим. Он используется для обработки всех исключений, которые не были перехвачены отдельными except .
try: print('1'+1) print(sum) print(1/0) except NameError: print("sum не существует") except ZeroDivisionError: print("Вы не можете разделить на 0") except: print("Что-то пошло не так. ")
Здесь первая инструкция блока пытается осуществить операцию конкатенации строки python с числом. Это приводит к ошибке TypeError . Как только интерпретатор сталкивается с этой проблемой, он проверяет соответствующий блок except , который ее обработает.
Отдельную инструкцию нельзя разместить между блоками try и except .
try: print("1") print("2") except: print("3")
Это приведет к синтаксической ошибке.
Но может быть только один общий или блок по умолчанию типа except . Следующий код вызовет ошибку «default ‘except:’ must be last» :
try: print(1/0) except: raise except: print("Исключение поймано") finally: print("Хорошо") print("Пока")
4. Блок finally в Python
После последнего блока except можно добавить блок finally . Он исполняет инструкции при любых условиях.
try: print(1/0) except ValueError: print("Это ошибка значения") finally: print("Это будет напечатано в любом случае.")
Это будет напечатано в любом случае. Traceback (most recent call last): File “”, line 2, in print(1/0) ZeroDivisionError: division by zero
Стоит обратить внимание, что сообщение с ошибкой выводится после исполнения блока finally . Почему же тогда просто не использовать print ? Но как видно по последнему примеру, блок finally запускается даже в том случае, если перехватить исключение не удается.
А что будет, если исключение перехватывается в except ?
try: print(1/0) except ZeroDivisionError: print(2/0) finally: print("Ничего не происходит")
Ничего не происходит Traceback (most recent call last): File "", line 2, in print(1/0) ZeroDivisionError: division by zero During handling of the above exception, another exception occurred: Traceback (most recent call last): File "", line 4, in print(2/0) ZeroDivisionError: division by zero
Как видите, код в блоке finally исполняется в любом случае.
5. Ключевое слово raise в Python
Иногда нужно будет разбираться с проблемами с помощью вызова исключения. Обычная инструкция print тут не сработает.
Traceback (most recent call last): File "", line 1, in raise ZeroDivisionError ZeroDivisionError
Разберемся на примере операции деления:
a,b=int(input()),int(input()) # вводим 1 затем 0 if b==0: raise ZeroDivisionError
Traceback (most recent call last): File "", line 3, in raise ZeroDivisionError ZeroDivisionError
Здесь ввод пользователя в переменные a и b конвертируется в целые числа. Затем проверяется, равна ли b нулю. Если да, то вызывается ZeroDivisionError .
Что будет, если то же самое добавить в блоки try-except? Добавим следующее в код. Если запустить его, ввести 1 и 0, будет следующий вывод:
a,b=int(input()),int(input()) try: if b==0: raise ZeroDivisionError except: print("Деление на 0") print("Будет ли это напечатано?")
1 0 Деление на 0 Будет ли это напечатано?
Рассмотрим еще несколько примеров, прежде чем двигаться дальше:
Traceback (most recent call last): File “”, line 1, in raise KeyError KeyError
a. Raise без определенного исключения в Python
Можно использовать ключевое слово raise и не указывая, какое исключение вызвать. Оно вызовет исключение, которое произошло. Поэтому его можно использовать только в блоке except .
Traceback (most recent call last): File “”, line 2, in print(‘1’+1) TypeError: must be str, not int
b. Raise с аргументом в Python
Также можно указать аргумент к определенному исключению в raise . Делается это с помощью дополнительных деталей исключения.
raise ValueError("Несоответствующее значение")
Traceback (most recent call last): File "", line 1, in raise ValueError("Несоответствующее значение") ValueError: Несоответствующее значение
6. assert в Python
Утверждение (assert) — это санитарная проверка для вашего циничного, параноидального «Я». Оно принимает инструкцию в качестве аргумента и вызывает исключение Python, если возвращается значение False . В противном случае выполняет операцию No-operation (NOP).
assert(True) # код работает дальше
Если бы инструкция была False ?
Traceback (most recent call last): File “”, line 1, in assert(1==0) AssertionError
try: print(1) assert 2+2==4 print(2) assert 1+2==4 print(3) except: print("assert False.") raise finally: print("Хорошо") print("Пока")
1 2 assert False. Хорошо Traceback (most recent call last): File “”, line 5, in assert 1+2==4 AssertionError
Утверждения можно использовать для проверки валидности ввода и вывода в функции.
a. Второй аргумент для assert
Можно предоставить второй аргумент, чтобы дать дополнительную информацию о проблеме.
Traceback (most recent call last): File “”, line 1, in assert False,”Это проблема” AssertionError: Это проблема
7. Объявление собственных исключений Python
Наконец, рассмотрим процесс создания собственных исключений. Для этого создадим новый класс из класса Exception . Потом его можно будет вызывать как любой другой тип исключения.
class MyError(Exception): print("Это проблема") raise MyError("ошибка MyError")
Traceback (most recent call last): File “”, line 1, in raise MyError(“ошибка MyError”) MyError: ошибка MyError
Вот и все, что касается обработки исключений в Python.
8. Вывод: обработка исключений Python
Благодаря этой статье вы сможете обеспечить дополнительную безопасность своему коду. Все благодаря возможности обработки исключений Python, их вызова и создания собственных.
Python ValueError Exception Handling Examples
While we believe that this content benefits our community, we have not yet thoroughly reviewed it. If you have any suggestions for improvements, please let us know by clicking the “report an issue“ button at the bottom of the tutorial.
1. What is Python ValueError?
Python ValueError is raised when a function receives an argument of the correct type but an inappropriate value. Also, the situation should not be described by a more precise exception such as IndexError.
2. ValueError Example
>>> import math >>> >>> math.sqrt(-10) Traceback (most recent call last): File "", line 1, in ValueError: math domain error >>>
3. Handling ValueError Exception
import math x = int(input('Please enter a positive number:\n')) try: print(f'Square Root of is ') except ValueError as ve: print(f'You entered , which is not a positive number.')
Please enter a positive number: 16 Square Root of 16 is 4.0 Please enter a positive number: -10 You entered -10, which is not a positive number. Please enter a positive number: abc Traceback (most recent call last): File "/Users/pankaj/Documents/PycharmProjects/hello-world/journaldev/errors/valueerror_examples.py", line 11, in x = int(input('Please enter a positive number:\n')) ValueError: invalid literal for int() with base 10: 'abc'
Our program can raise ValueError in int() and math.sqrt() functions. So, we can create a nested try-except block to handle both of them. Here is the updated snippet to take care of all the ValueError scenarios.
import math try: x = int(input('Please enter a positive number:\n')) try: print(f'Square Root of is ') except ValueError as ve: print(f'You entered , which is not a positive number.') except ValueError as ve: print('You are supposed to enter positive number.')
4. Raising ValueError in a function
Here is a simple example where we are raising ValueError for input argument of correct type but inappropriate value.
import math def num_stats(x): if x is not int: raise TypeError('Work with Numbers Only') if x < 0: raise ValueError('Work with Positive Numbers Only') print(f'square is ') print(f' square root is ')
5. References
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.