«Оператор assert — простой способ вставить отладочные утверждения в программу». Он является простым утверждением, которое проверяет истинность выражения.
Когда условие в assert истинно, программа продолжает выполнение без каких-либо изменений.
Если же условие ложно, assert вызывает исключение AssertionError, что приводит к немедленному завершению программы.
assert может принимать необязательное сообщение об ошибке, которое будет выведено при срабатывании исключения.
В нашем случае assert x < y, "x должно быть меньше y" проверяет, что переменная x действительно меньше y.
Поскольку 15 < 10 является ложным утверждением, assert вызывает исключение и останавливает дальнейшую интерпретацию кода.
x = 15
y = 10
assert x < y, "x должно быть меньше y" # AssertionError: x должно быть меньше y
print("Условие выполнено") # Не отработает вообще
Важно понимать, что `assert` предназначен для отладки и проверки инвариантов программы, а не для обработки ошибок времени выполнения.
❤1👍1👎1
Какие типы задач вы решаете?
Anonymous Poll
38%
Как на LeetCode («Напишите функцию…»)
38%
Как здесь: вопросы с вариантами ответов
43%
Сейчас не решаю
5%
Другое
👍1👎1
👍1👎1
В данном коде присутствуют два активных оператора try — один в функции action1 и один на верхнем уровне модуля.
Функция action2() генерирует исключение TypeError при попытке сложить число 1 и пустой список [], поскольку складывать числа и последовательности нельзя.
«Когда action2 сгенерирует исключение `TypeError`, интерпретатор Python выберет и выполнит самый недавний try с совпадающей конструкцией except, которым в данном случае будет `try` внутри функции action1()».
Поэтому исключение `TypeError` будет перехвачено внутренним обработчиком except TypeError: print('inner try'), и на экран выведется 'inner try'.
Внешний `try` блок не выполнится, так как исключение уже было обработано на более глубоком уровне вложенности.
👍1👎1
🪤 Что выведет код?
Anonymous Quiz
70%
Выведется "Bye" и создастся badly.exc
11%
Выведется "Bye"
11%
Ничего не выведется, файлов не будет создано
8%
Error
👍2👎1
«В коде используется удобная функция print_exc из модуля traceback, которая по умолчанию потребляет данные sys.exc_info; после запуска сценарий выводит сообщение об ошибке в файл, что удобно в тестовых программах, которым необходимо перехватывать ошибки, но вдобавок полноценно их регистрировать».
В блоке обработки исключения вызывается traceback.print_exc(file=open('badly.exc','w')), который:
После успешной обработки исключения выполнение продолжается, и выводится "Bye". Таким образом, код не завершается с ошибкой, а успешно обрабатывает исключение и создает файл с информацией об ошибке.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1👎1
🧩 Какой способ проверки вхождения "Las Vegas" верный?
Anonymous Quiz
13%
cities.str.contains("Las Vegas", na=False).any()
21%
"Las Vegas" in cities.values
10%
cities.isin(["Las Vegas"]).any()
56%
Все варианты верны
👍1👎1
Выполняет поэлементный поиск подстроки (regex или литерал) внутри строк.
В Pandas Series.values возвращает numpy.ndarray. Выполняет проверку наличия точного значения в массиве NumPy.
Проверяет для каждого элемента Series, содержится ли он в списке значений. Возвращает True, если хотя бы один элемент Series строго равен "Las Vegas".
👍1👎1
👍1👎1
Поймано: RuntimeError
Причина: ValueError
D функции process_data() происходит попытка преобразовать строку "abc" в целое число, что вызывает ValueError. Затем это исключение перехватывается и перебрасывается как RuntimeError с помощью конструкции raise ... from e, которая сохраняет связь между исключениями. Внешний блок try-except ловит RuntimeError и выводит информацию о типе пойманного исключения и его причине через атрибут __cause__.
👍1👎1
«Результат вызова sys. exc inf о, который применялся в предшествующих двух разделах, дает возможность обработчику исключений получать доступ к самому последнему cгенерированному исключению обобщенным образом. Это особенно полезно при использовании пустой конструкции except для слепого перехвата всех исключений,
чтобы выяснить, какое исключение было сгенерировано:
import sys
try:
...
except:
# sys.exc_info()[0:2] представляет класс и экземпляр исключения
Если никакие исключения не обрабатывались, тогда такой вызов возвращает кортеж с тремя значениями None. В противном случае значениями будут (type, value, traceback):
— type — класс обрабатываемого исключения;
— value — экземпляр класса исключения, который был сгенерирован;
— traceback — объект трассировки, который представляет стек вызовов в месте,
где первоначально возникло исключение, и применяется модулем traceback для генерации сообщений об ошибках».
👍2❤1👎1
❤1👍1👎1
«В коде используется удобная функция `print_exc` из модуля `traceback`, которая по умолчанию потребляет данные `sys.exc_info`»
Исключение уже было перехвачено блоком except Exception. Когда происходит деление на ноль в функции inverse(0), Python генерирует `ZeroDivisionError`, но этот блок except перехватывает исключение и предотвращает его дальнейшее распространение.
После перехвата исключения:
1. `traceback.print_exc(file=open('badly.exc', 'w'))` - записывает информацию об ошибке в файл `badly.exc`
2. `print('Bye')` - выполняется нормально, так как исключение уже обработано
«traceback.print_exc() потребляет данные sys.exc_info - это означает, что функция извлекает информацию о последнем исключении и форматирует её для вывода, но не прерывает выполнение программы.
❤1👍1👎1