Ответы пользователя по тегу Python
  • Ошибка пайтон как исправить?

    Vindicar
    @Vindicar
    RTFM!
    У тебя какая-то очень древняя версия питона, еще до 3.5.
    Ответ написан
    Комментировать
  • Как ускорить выполнение перебора?

    Vindicar
    @Vindicar
    RTFM!
    Задумайся для начала.
    Зачем ты для каждой попытки i заново суммируешь числа от 1 до i-1, если ты уже суммировал их на предыдущей итерации?
    Если не осилил

    m = .....
    n = 0
    while m > 0:
        n += 1
        m -= n ** 3
    print(n)

    Ответ написан
    Комментировать
  • Почему при подсчете количества строк в SQLite3 выводится не число, а 0x0000009E9DC70E30>?

    Vindicar
    @Vindicar
    RTFM!
    1. Ты получил объект-курсор. У него нет строкового представления, поэтому пр ивыводе он отображается по умолчанию - <Cursor object at адрес-объекта-в-памяти>
    Чтобы получить выбранные данные, нужно вызывать методы fetchone() или fetchall().
    2. Если ты делаешь запрос к БД, который возвращает данные (неважно какие), получить их придётся как описано выше. Что это за данные - сами строки, какая-то агрегатная функция, или еще что - не важно. Даже если выполнишь запрос вида SELECT 123;, всё равно результат придётся вытаскивать через fetchone()/fetchall().
    3. SUM(id) вернёт тебе сумму всех идентификаторов строк в таблице, а не количество строк в ней. Используй COUNT(*).
    Ответ написан
    Комментировать
  • Детектор движения отдельных объектов OpenCV на Python, как можно реализовать?

    Vindicar
    @Vindicar
    RTFM!
    Такой вопрос уже был, повторю свой ответ: создай изображение-маску, и по этой маске закрашивай одним цветом неинтересные тебе части кадра перед их отправкой на сравнение. В закрашенных частях движения не будет по определению.
    Ответ написан
    Комментировать
  • Информация, введённая в массив, забывается после закрытия консоли, как заставить её сохраняться?

    Vindicar
    @Vindicar
    RTFM!
    Массив хранится в оперативной памяти.
    Когда ты завершаешь процесс, вся выделенная ему оперативная память освобождается и потом используется другими процессами. Это действие выполняется операционной системой, у приложений нет над ним никакого контроля.
    Вывод: неважно что ты делаешь с переменной, её значение не сохранится, если ты сам об этом не позаботишься.

    Так что читай про то, как пользоватсья модулем json и работать с файлами. Это будет самый простой вариант.
    Ответ написан
    2 комментария
  • Как оптимально проверить вхождение элемента из одного списка в другом?

    Vindicar
    @Vindicar
    RTFM!
    Для ситуации, когда "чёрный список" длинный, но статичный, а элементы можно сравнивать, может иметь смысл отсортировать списки и двигаться по обоим. Если списки отсортированы заранее, то сложность будет O(M+N), вместо O(M*N). Если не отсортированы, то всё будет определяться скоростью сортировки.

    black_list = list('1234567890h')
    black_list.sort()
    tested_list = list('dabeghfc')
    tested_list.sort()
    black_last, tested_last = len(black_list)-1, len(tested_list)-1
    black_idx, tested_idx = 0, 0
    black_item, tested_item = black_list[black_idx], tested_list[tested_idx]
    while True:
        if black_item < tested_item and black_idx < black_last:
            # элемент в чёрном списке меньше - идём вперёд по чёрному списку, если есть куда
            black_idx += 1
            black_item = black_list[black_idx]
        elif black_item > tested_item and tested_idx < tested_last:
            # элемент в чёрном списке больше - идём вперёд по тестирумому списку, если есть куда
            tested_idx += 1
            tested_item = tested_list[tested_idx]
        else:  # либо элементы равны (есть вхождение), либо один из списков закончился
            break
    print('Есть вхождение!' if black_item == tested_item else 'Нет вхождения')
    Ответ написан
    Комментировать
  • Какая ошибка в коде телеграмм бот(aiogram)?

    Vindicar
    @Vindicar
    RTFM!
    hm = message.text == int
    Я догадываюсь, что ты пытаешься проверить, что введено целое число (а почему целое?), но это так не работает.

    А чтобы организовать сообщения от пользователя в цепочку, смотри в сторону register_next_step_handler().
    Ответ написан
    Комментировать
  • Что тут учить в библиотеке aiogram?

    Vindicar
    @Vindicar
    RTFM!
    1. Читаешь Quick Start и примеры кода.
    2. Ищешь пример кода, который наиболее походит на нужную тебе функциональность.
    3. Наткнувшись на непонятное, ищешь нужный раздел документации и читаешь до наступления просветления.
    4. Повторять 2-3, пока нужный пример кода не будет полностью понятен.
    Я так делаю, во всяком случае.
    Ответ написан
    1 комментарий
  • Как определить качество изображения?

    Vindicar
    @Vindicar
    RTFM!
    Ну например, так: используй фильтр Кэнни на изображении, посчитай число белых пикеселей (контуров).
    Размой изображение слегка и используй фильтр Кэнни на размытом изображении. Белый пикселей (контуров) будет меньше, так как часть контуров станет слишком размыта. Чем размытее изображение, тем меньше будет разница.
    Ответ написан
    Комментировать
  • Как сделать так, что бы таймер начинался заново, а не накладывался друг на друга в tkinter?

    Vindicar
    @Vindicar
    RTFM!
    Сделать count глобальной переменной. Тогда её значением можно будет управлять извне countdown().
    Ответ написан
  • Как работать с foreign key sqlite3 через python, нигде понятного объяснения не нашёл?

    Vindicar
    @Vindicar
    RTFM!
    Питон тут нипричем. Читаем доки по sqlite, находим пример:
    CREATE TABLE artist(
      artistid    INTEGER PRIMARY KEY, 
      artistname  TEXT
    );
    CREATE TABLE track(
      trackid     INTEGER,
      trackname   TEXT, 
      trackartist INTEGER REFERENCES artist(artistid) ON UPDATE CASCADE
    );

    Пример обеспечивает каскадное обновление ключа (ты вроде это просишь).
    Также может потребоваться включить поддержку внешних ключей, выполнив первым делом запрос:
    PRAGMA foreign_keys = ON;
    Ответ написан
    Комментировать
  • Ошибка синтаксиса, как исправить?

    Vindicar
    @Vindicar
    RTFM!
    while False:
    while False: что? Тела-то у цикла нет. Да и смысла в нём тоже.
    Ответ написан
    Комментировать
  • Где у меня ошибка в коде в задании 15.2 Информатика Python?

    Vindicar
    @Vindicar
    RTFM!
    Потому что пишешь какую-то ерунду.
    round(int(input())) - зачем тебе round()? Ты же читаешь целое число.
    1 < k < 30 зачем это проверять на каждой итерации цикла? И да, это условие провалится если тебе передадут 1 или 30 значений.
    1 < number < 300 - опять, зачем? Тебе по условию сказано, что вводимые значения будут именно такими, это условие ничего не делает. Кроме случаев, когда скорость равна 1 или 300 - по условию такое может быть, а у тебя нет.
    Дальше, почему ты постоянно переписываешь переменную a? Её нужно переписывать только если есть автомобиль, скорость которого меньше 30 км/ч. В твоём коде, если сначала будет автомобиль со скоростью меньше, а потом со скоростью больше, то программа забудет, что видела медленный автомобиль.
    Ответ написан
    3 комментария
  • Как вывести определённый элемент в json python?

    Vindicar
    @Vindicar
    RTFM!
    Ты пропустил ключ 'users'. А в этом ключе еще один список.
    Вообще структура данных абсолютно всратая, её не прочитаешь даже толком.
    Тебе придётся этот список-users перебирать, и искать в нём элемент словарь, у которого есть ключ с именем нужного пользователя.
    Ответ написан
    Комментировать
  • Пишу бота для телеграм (telebot), проблема с асинхронными функциями. В чем причина ошибки?

    Vindicar
    @Vindicar
    RTFM!
    1. await так не пишется.
    x = await asyncio.create_task(startq(message))
    2. Зачем ты делаешь await?
    asyncio.create_task() создаёт корутину, которая будет выполняться конкуррентно с текущей (как бы параллельно)
    await приостанавливает выполнение текущей корутины, пока не завершится вызываемая (справа от await).
    Т.е. await create_task(...) - это не очень осмысленно: сначала запускаешь параллельную корутину, а потом всё равно стоишь и ждёшь её.
    Если тебе нужно запустить корутину startq() и дождаться её выполнения (ну и получить возвращаемое значение) - пиши просто x = await startq(message)
    Если тебе нужно запустить корутину startq() и пусть она дальше выполняется сама по себе, тебе от неё ничего не надо - достаточно будет asyncio.create_task(startq(message))
    Ответ написан
    1 комментарий
  • Как создать свой PL?

    Vindicar
    @Vindicar
    RTFM!
    Даже для простого ЯП тебе придётся решить минимум четыре задачи:
    1. Лексический анализ. Входной текст нужно превратить в цепочку токенов, например z = x + y превратится в что-то типа
    [ (token.IDENTIFIER, 'z'), (token.OPERATOR, '=') (token.IDENTIFIER, 'x'), (token.OPERATOR, '+') (token.IDENTIFIER, 'y') ]

    2. Синтаксический анализ. Тебе нужно превратить цепочку токенов в древовидную структуру. Корень дерева - программа целиком, промежуточные узлы - элементы программы (функции, составные операторы, сложные выражения и пр.), листья - отдельные элементы сложных выражений и примитивные операции без параметров (типа pass в питоне).
    Например цикл while будет иметь два дочерних узла: выражение-условие и тело цикла.
    3. Области видимости. Тебе нужно иметь возможность сопоставить имя(идентификатор) и сущность (переменную, функцию и т.п.).
    Самый простой способ - позволить узлу дерева описывать идентификаторы, которые известны в этом узле. Тогда при раскрытии идентификатора достаточно подняться вверх по дереву, пока не найдёшь нужное имя.
    4. Выполнение. Так как ты хочешь интерпретируемый язык, то выполнение будет сводиться к обходу дерева в глубину. Некоторые операторы типа break могут вмешиваться в этот порядок. Это описывается паттерном Интерпретатор из набора Банды Четырёх.

    Отдельные задачи в этом списке вполне себе гуглятся, и могут решаться по-разному.
    Ответ написан
    1 комментарий
  • Не сохраняется файл после выполнения кода python, что делать?

    Vindicar
    @Vindicar
    RTFM!
    open('text1.txt', 'w', encoding='utf-8')
    Относительный путь. Файл сохраняется где-то в текущем рабочем каталоге, а не рядом с исходным файлом.
    Судя по тому, что для исходного файла ты указываешь полный путь, у тебя текущий рабочий каталог не на рабочем столе.
    Раз уж используешь pathlib, сконструируй полный путь для целевого файла, типа
    srcpath = Path(file_path)
    if srcpath.is_file() and srcpath.suffix == '.pdf':
        ...
        with (srcpath.parent / 'text1.txt').open('wt', encoding='utf-8') as file:
            ...
    Ответ написан
    2 комментария
  • Что возвращает sql запрос, если поле пустое?

    Vindicar
    @Vindicar
    RTFM!
    HardX, произойдёт то же самое, как при попытке итерироваться по пустому списку.
    Тело цикла просто не выполнится ни разу, и всё.

    empty_list = []
    print('Before')
    for item in empty_list:
        print('Item:', item)
    print('After')
    Ответ написан
  • Почему телеграм бот не запускает?

    Vindicar
    @Vindicar
    RTFM!
    Потому что ты не думаешь, что ты пишешь.
    message.text.lower() == "Привет"
    Ты сравниваешь строку, которая переведена целиком в нижний регистр (т.е. не содержит заглавных букв) со строкой, которая содержит заглавные буквы.
    Ответ написан
    Комментировать