Traceback most recent call last как исправить
Перейти к содержимому

Traceback most recent call last как исправить

  • автор:

Ошибка Traceback (most recent call last): (Python)

написал код который генерирует рандомные пароли вот собственно сам код:

import random from random import choice from string import ascii_uppercase def test(): cs = random.randint(8,25) symbols = 'abcdefghijklnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890_' rand = (''.join(choice(symbols) for i in range(cs))) if rand == "testPIN12345": print (rand) else: test() test() 

по идеи он должен работать до тех пор пока не сгенерирует рандомный пароль совпадающий со значением в if rand == «testPIN12345»: но вылетает ошибка:

Traceback (most recent call last): File "C:\test\test.py", line 19, in test() File "C:\test\test.py", line 17, in test test() File "C:\test\test.py", line 17, in test test() File "C:\test\test.py", line 17, in test test() [Previous line repeated 1017 more times] File "C:\test\test.py", line 12, in test rand = (''.join(choice(symbols) for i in range(cs))) File "C:\test\test.py", line 12, in rand = (''.join(choice(symbols) for i in range(cs))) File "C:\Users\epicb\AppData\Local\Programs\Python\Python38\lib\random.py", line 288, in choice i = self._randbelow(len(seq)) File "C:\Users\epicb\AppData\Local\Programs\Python\Python38\lib\random.py", line 254, in _randbelow_with_getrandbits k = n.bit_length() # don't use (n-1) here because n can be 1 RecursionError: maximum recursion depth exceeded while calling a Python object 

Повторение материала. Работа с ошибками в Python.

Наш код подразумевает печать содержимого переменной vector.

Запустим написанный скрипт, получим следующий вывод:

$ python3 solution.py Traceback (most recent call last): File "solution.py", line 1, in for coord in vector: NameError: name 'vector' is not defined 

Сообщение означает, что при исполнении кода возникла ошибка. При этом Python сообщает нам кое-что ещё. Разберём это сообщение детально.

Чтение Traceback 1

Исходное сообщение нужно мысленно разделить на две части. Первая часть это traceback-сообщение:

Traceback (most recent call last): File "solution.py", line 1, in for coord in vector:

Вторая часть — сообщение о возникшей ошибке:

NameError: name 'vector' is not defined

Разберём первую часть. Traceback в грубом переводе означает «отследить назад». Traceback показывает последовательность/стэк вызовов, которая, в конечном итоге, вызвала ошибку.

Traceback (most recent call last):

является заголовочной. Она сообщает, что в последующих строках будет изложен стэк вызовов (он показан отступами). Обратите внимание на сообщение в скобках, оно указывает на порядок вызовов. В данном случае (он же случай по умолчанию) тот вызов, в котором произошла ошибка, будет в последовательности вызовов указан последним.

Вторая и третья строки:

File "solution.py", line 1, in for coord in vector:

показывают информацию о вызове (в нашем случае он один). Во-первых, здесь есть информация о файле, в котором произошёл вызов («solution.py»), затем указан номер строки, где этот вызов происходит («line 1»), в конце стоит информация о том, откуда произошёл вызов («»). В нашем случае вызов происходит непосредственно из модуля, т.е. не из функции. Наконец, вывод содержит не только номер строки, но и саму строку «for coord in vector:».

Заключительная строка сообщения:

NameError: name 'vector' is not defined

содержит вид (тип) ошибки («NameError»), и после двоеточия содержит подсказку. В данном случае она означает, что имя «vector» не определено.

В самом деле, если взглянуть снова на код, то можно убедиться, что мы нигде не объявили переменную «vector».

Подведём итоги. При попытке запуска мы получили следующий вывод

$ python3 solution.py Traceback (most recent call last): File "solution.py", line 1, in for coord in vector: NameError: name 'vector' is not defined 

Он говорит нам о возникновении ошибки. Эта ошибка обнаружилась интерпретатором в первой строке файла «solution.py». Сама ошибка является ошибкой имени и указывает на необъявленное имя — «vector».

Чтение Traceback 2

Оберните код из solution.py в функцию:

1 2 3 4 5
def print_vector(vector): for coord in vector: print(coord) print_vector(5) 

Запустим наш код

$ python3 solution.py Traceback (most recent call last): File "solution.py", line 5, in print_vector(5) File "solution.py", line 2, in print_vector for coord in vector: TypeError: 'int' object is not iterable 

На этот раз сообщение об ошибке сложнее, однако структура у него та же.

Часть со стеком вызовов увеличилась:

Traceback (most recent call last): File "solution.py", line 5, in print_vector(5) File "solution.py", line 2, in print_vector for coord in vector:

Поскольку «most recent call last», читать будем её сверху вниз.

Вызовов на этот раз два. Первый вызов:

File "solution.py", line 5, in print_vector(5)

Произошел в пятой строке. Судя по строчке кода, это вызов написанной нами функции print_vector(5) с аргументом 5.

Следом за ней второй вызов:

File "solution.py", line 2, in print_vector for coord in vector:

Этот вызов происходит внутри функции print_vector, содержащейся в файле «solution.py». Вызов находится в строке 2.

Сама же ошибка имеет вид:

TypeError: 'int' object is not iterable

Как и в первом примере, сообщение об ошибке содержит её тип и подсказку. В нашем случае произошла ошибка типа. В подсказке же указано, что объект типа int не является итерируемым, т.е. таким объектом, который нельзя использовать в цикле for.

$ python3 solution.py Traceback (most recent call last): File "solution.py", line 5, in print_vector(5) File "solution.py", line 2, in print_vector for coord in vector: TypeError: 'int' object is not iterable 

В нашем коде возникла ошибка. Её вызвала последовательность вызовов. Первый вызов произошел непосредственно из модуля — в строке 5 происходит вызов функции print_vector(5). Внутри этой функции ошибка возникла в строчке 2, содержащей проход по циклу. Сообщение об ошибке означает, что итерироваться по объекту типа int нельзя. В нашем случае мы вызвали функцию print_vector от числа (от 5).

Некоторые ошибки с примерами кода

Ошибки в синтаксисе

Наиболее частая ошибка, которая возникает в программах на Python — SyntaxError: когда какое-то утверждение записано не по правилам языка, например:

$ python3 >>> print "hello" File "", line 1 print "hello" ^ SyntaxError: Missing parentheses in call to 'print'. Did you mean print("hello")? 

Тот же тип ошибки возникнет, если забыть поставить двоеточие в цикле:

$ python3 >>> for i in range(5) File "", line 1 for i in range(5) ^ SyntaxError: invalid syntax 

При неправильном использовании пробелов и табуляций в начале строки возникает IndentationError:

$ python3 >>> for i in range(5): print(i) File "", line 2 print(i) ^ IndentationError: expected an indented block 

А теперь посмотрим, что будет, если в первой строке цикла воспользоваться пробелами, а во второй — табуляцией:

$ python3 >>> for i in range(5): print(i) # здесь пробелы print(i**2) # здесь табуляция File "", line 3 print(i**2) ^ TabError: inconsistent use of tabs and spaces in indentation 

NameError возникает при обращении к несуществующей переменной:

$ python3 >>> words = "Hello" >>> word Traceback (most recent call last): File "", line 1, in NameError: name 'word' is not defined 

Ошибки в логике

Напишем простую программу на деление с остатком и сохраним как sample.py:

n = input() m = input() print(n % m) 
$ python3 sample.py 5 3 Traceback (most recent call last): File "sample.py", line 3, in print(n % m) TypeError: not all arguments converted during string formatting 

Возникла ошибка TypeError, которая сообщает о неподходящем типе данных. Исправим программу:

n = int(input()) m = int(input()) print(n % m) 

запустим на неподходящих данных:

$ python3 sample.py xyz Traceback (most recent call last): File "sample.py", line 1, in n = int(input()) ValueError: invalid literal for int() with base 10: 'xyz' 

Возникнет ValueError. Эту ошибку ещё можно воспринимать как использование значения вне области допустимых значений (ОДЗ).

Теперь запустим программу на числовых данных:

$ python3 sample.py 1 0 Traceback (most recent call last): File "sample.py", line 3, in print(n % m) ZeroDivisionError: integer division or modulo by zero 

При работе с массивами нередко возникает ошибка IndexError. Она возникает при выходе за пределы массива:

$ python3 >>> L1 = [1, 2, 3] >>> L1[3] Traceback (most recent call last): File "", line 1, in IndexError: list index out of range 

Что будет, если вызвать бесконечную рекурсию? Опишем её в программе endless.py

def noend(): print("Hello!") noend() noend() 

Через некоторое время после запуска возникнет RecursionError:

Traceback (most recent call last): File "endless.py", line 4, in noend() File "endless.py", line 3, in noend noend() File "endless.py", line 3, in noend noend() File "endless.py", line 3, in noend noend() [Previous line repeated 993 more times] File "endless.py", line 2, in noend print("Hello!") RecursionError: maximum recursion depth exceeded while calling a Python object 

Контест №1

Сайт построен с использованием Pelican. За основу оформления взята тема от Smashing Magazine. Исходные тексты программ, приведённые на этом сайте, распространяются под лицензией GPLv3, все остальные материалы сайта распространяются под лицензией CC-BY.

Программа не работает. Что делать?

Python 3 логотип

Моя программа не работает! Что делать? В данной статье я постараюсь собрать наиболее частые ошибки начинающих программировать на python 3, а также расскажу, как их исправлять.

Проблема: Моя программа не запускается. На доли секунды появляется чёрное окошко, а затем исчезает.

Причина: после окончания выполнения программы (после выполнения всего кода или при возникновении исключения программа закрывается. И если вы её вызвали двойным кликом по иконке (а вы, скорее всего, вызвали её именно так), то она закроется вместе с окошком, в котором находится вывод программы.

Решение: запускать программу через IDLE или через консоль.

Проблема: Не работает функция input. Пишет SyntaxError.

Пример кода:

   File 

Причина: Вы запустили Python 2.

Проблема: Где-то увидел простую программу, а она не работает.

Пример кода:

Ошибка:
Причина: Вам подсунули программу на Python 2.

Решение: Прочитать об отличиях Python 2 от Python 3. Переписать её на Python 3. Например, данная программа на Python 3 будет выглядеть так:

Проблема: TypeError: Can’t convert ‘int’ object to str implicitly.

Пример кода:

Причина: Нельзя складывать строку с числом.

Решение: Привести строку к числу с помощью функции int(). Кстати, заметьте, что функция input() всегда возвращает строку!

Проблема: SyntaxError: invalid syntax.

Пример кода:

Ошибка:
Причина: Забыто двоеточие.

Проблема: SyntaxError: invalid syntax.

Пример кода:

Ошибка:
Причина: Забыто равно.

Проблема: NameError: name ‘a’ is not defined.

Пример кода:

Причина: Переменная "a" не существует. Возможно, вы опечатались в названии или забыли инициализировать её.

Решение: Исправить опечатку.

Проблема: IndentationError: expected an indented block.

Пример кода:

Причина: Нужен отступ.

Проблема: TabError: inconsistent use of tabs and spaces in indentation.

Пример кода:

Ошибка:
Причина: Смешение пробелов и табуляции в отступах.

Решение: Исправить отступы.

Проблема: UnboundLocalError: local variable ‘a’ referenced before assignment.

Пример кода:

Ошибка:
Причина: Попытка обратиться к локальной переменной, которая ещё не создана.

Проблема: Программа выполнилась, но в файл ничего не записалось / записалось не всё.

Пример кода:

 Причина: Не закрыт файл, часть данных могла остаться в буфере.

Проблема: Здесь может быть ваша проблема. Комментарии чуть ниже 🙂

Также вам может быть полезно это описание:

Для вставки кода на Python в комментарий заключайте его в теги

  • Модуль csv - чтение и запись CSV файлов
  • Создаём сайт на Django, используя хорошие практики. Часть 1: создаём проект
  • Онлайн-обучение Python: сравнение популярных программ
  • Книги о Python
  • GUI (графический интерфейс пользователя)
  • Курсы Python
  • Модули
  • Новости мира Python
  • NumPy
  • Обработка данных
  • Основы программирования
  • Примеры программ
  • Типы данных в Python
  • Видео
  • Python для Web
  • Работа для Python-программистов
  • Сделай свой вклад в развитие сайта!
  • Самоучитель Python
  • Карта сайта
  • Отзывы на книги по Python
  • Реклама на сайте

Python Ошибка Traceback (most recent call last): Как исправить?

Нужно написать код который парсит каталог товаров из интернет магазина на примере e-katalog и выгружает в таблицу .csv для дальнейшего импорта в WordPress WooCommerce, но это уже отдельная тема. Пока подключил библиотеки. При запуске кода создается .csv с заголовками, но информации по товарам нет. Код выглядит так:

import requests import csv import time from lxml import html from fake_headers import Headers HEADERS = Headers( browser="chrome", os="win", headers=True ).generate() URL = 'https://www.e-katalog.ru/list/431/' DOMAIN = 'https://www.e-katalog.ru' ALL_DATA = dict() QUEUE_URL = set() def add_to_csv_from_file(product_dict): with open('data.csv', 'a') as csvfile: fieldnames = ["Name", "Price", "Url", "Title"] writer = csv.DictWriter(csvfile, fieldnames=fieldnames, quoting=csv.QUOTE_ALL) writer.writerow(product_dict) def get_data(product_link): product = dict() request = requests.get(product_link, headers=HEADERS) tree = html.fromstring(request.content) product_name = tree.xpath("//h1/text()") product_price = tree.xpath("//div[@class='desc-short-prices'][1]//" "div[@class='desc-big-price ib']//span[1]/text()") product['Url'] = product_link product['Title'] = tree.findtext('.//title') for name in product_name: product['Name'] = name for price in product_price: product['Price'] = price time.sleep(3) print('Сбор данных с URL', product_link) return product def get_links(page_url): pagination_pages = set() request = requests.get(page_url, headers=HEADERS) tree = html.fromstring(request.content) pages_count = tree.xpath('//div[@class="ib page-num"]//a[last()]/text()') print('\nКод ответа корневого УРЛ:', request.status_code) print('Всего страниц пейджинации:', pages_count) for url in range(int(pages_count[0])): full_url = f"https://www.e-katalog.ru/list/431//" pagination_pages.add(full_url) while len(pagination_pages) != 0: current_url = pagination_pages.pop() print('Сбор ссылок с URL:', current_url) request = requests.get(current_url, headers=HEADERS) tree = html.fromstring(request.content) links = tree.xpath("//a[@class='model-short-title no-u']/@href") for link in links: QUEUE_URL.add(DOMAIN+link) time.sleep(3) def main(): with open('data.csv', 'a') as csvfile: fieldnames = ["Name", "Price", "Url", "Title"] writer = csv.DictWriter(csvfile, fieldnames=fieldnames, quoting=csv.QUOTE_ALL) writer.writeheader() get_links(URL) while len(QUEUE_URL) != 0: current_url = QUEUE_URL.pop() add_to_csv_from_file(get_data(current_url)) if __name__ == "__main__": main()

636b6c8d1458b188975949.png

Так выглядит ошибка

  • Вопрос задан более года назад
  • 2335 просмотров

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *