В начале traceback всегда есть строка Traceback (most recent call last). Как она помогает читать стек вызовов?
ATraceback показывает цепочку вызовов от внешнего к внутреннему, и самый нижний фрейм обычно ближе всего к месту ошибки.
BЭто означает, что ошибка уже была обработана и можно игнорировать остаток traceback.
CЭто означает, что ошибка произошла в самом первом фрейме списка.
DЭто означает, что Python выводит traceback в случайном порядке.
Правильный ответ. Traceback читают как стек вызовов: он показывает, какие функции привели к месту падения.
Разбор
Строка Traceback (most recent call last) подсказывает: ниже будет список вызовов, а «последний» вызов (внизу) — обычно там, где исключение возникло. Понимание этой структуры помогает быстро найти первопричину, а не лечить симптомы в верхних слоях кода.
Проверь себя · 1/3разбор после ответа
Вы парсите событие в словарь
event. Что произойдёт при обращении event["currency"], если ключа currency в словаре нет?Ещё вопросы по теме «Исключения и отладка»
- В обработчике данных вы используете конструкцию `try`/`except`/`finally`. Внутри `try` происходит ошибка, она поймана в `except`. Что произойдёт с кодом в `finally`?
- Вы парсите событие в словарь `event`. Что произойдёт при обращении `event["currency"]`, если ключа `currency` в словаре нет?
- В отчёте вы считаете сумму и случайно складываете число и строку: `total + "10"`. Какое исключение наиболее вероятно?
- Скрипт получает список строк, но иногда он короче ожидаемого. Что произойдёт при обращении `rows[3]`, если в списке всего 3 элемента?
- Вы пишете функцию, которая внутри `try` делает `return`, а в `finally` закрывает ресурс (например, файл или соединение). Что произойдёт с кодом в `finally` при `return` из `try`?
- Все вопросы по «Исключения и отладка» →