• Как сделать так чтобы пока пользователь не ввёл число в телеграмм бот он не продолжал программу а запрашивал число?

    Vindicar
    @Vindicar
    RTFM!
    Регистрировать эту же функцию process_num10_step через register_next_step_handler() в случае ошибки.
    Ответ написан
    Комментировать
  • Как заставить процесс запустить определённую процедуру?

    Vindicar
    @Vindicar
    RTFM!
    Если на пальцах:
    1. В питоне всё - оператор. Вот вообще всё, кроме комментариев. Объявление функции - такой же оператор, как и цикл.
    2. Как следствие, нет формального понятия "тело программы". Ты должен сам указать, что является телом, завернув его в if __name__ == '__main__:
    3. Чтобы выполнить подпрограмму, дочерний процесс должен выполнить код, который её определит. А единственный способ это сделать - выполнять файл с самого начала.
    4. Если ты не указал тело программы - дочерний процесс выполнит всё, в том числе запуск дочернего процесса. Что обычно не требуется.
    Так что правильно выглядящая программа с мультипроцессингом должна иметь только такой вид:
    def func1():
        ...
    
    def func2():
        ...
    
    ...
    if __name__ == '__main__':
        ... # тут запуск дочерних процессов


    А ещё данные передаются между процессами с помощью модуля pickle, так что твои распаралленные функции могут принимать и возвращать только такие объекты, которые можно упаковать с помощью pickle.
    Ответ написан
  • Можно ли сделать бота в телеграм, чтобы он уведомлял при появлении новых оценок на образовательной платформе edu.gounn?

    Vindicar
    @Vindicar
    RTFM!
    Декомпозируй задачу на подзадачи.
    1. Как получить сведения о новых оценках? Если нет никакого API уведомления (скажем, на почту), то остаётся только вариант "периодически опрашивать и сравнивать с прошлым результатом".
    Тут нужно пошариться по странице и понять, как она получает значения об оценках. Если эти значения вписаны уже в код HTML страницы - в помощь связка requests (ну или aiohttp) для скачивания страницы и bs4 для её разбора. Если эти значения подгружаются динамически через JS - это удобнее, можно выяснить, какой запрос подгружает сведения об оценках, и делать этот запрос самому. Инструменты разработчика в браузере помогут.

    2. Как отправить сведения об оценках?
    Если нет задачи управлять ботом через ТГ, а нужны исключительно оповещения на заранее заданный контакт, то необязательно делать полноценного бота - можно просто отправить запрос на сервер ТГ для отправки сообщения. Как - гуглится. Тогда у тебя основным скриптом будет парсер оценок, который будет дёргать функцию отправки уведомления.
    Если есть задача, чтобы бот хранил историю оценок, отвечал на запросы и т.д. - то нужен полноценный бот. В этом случае нужно будет разбираться, например, с асинхронными ботами, чтобы иметь возможность параллельно вести два набора действий - периодическую проверку оценок и реакцию на сообщения от юзеров.
    Ответ написан
    Комментировать
  • YOLOv8-seg Масштабирование маски. Как сделать правильно?

    Vindicar
    @Vindicar
    RTFM!
    Попробуй морфологическую диляцию. Если на пальцах, она делает белыми чёрные (фоновые) пиксели изображения, у которых есть белые соседи.
    Можно поиграться с ядром (определяет, что считать соседями) и с итерациями (сколько раз повторять диляцию).

    Поскольку маски объектов обычно белые на чёрном фоне, это "раздует" маску и одновременно сгладит её края.
    Ответ написан
  • Почему не работает python-valve?

    Vindicar
    @Vindicar
    RTFM!
    В репозитории код изменялся лет 5 назад, а документация - все 7. Так что придётся самостоятельно ориентироваться по коду - или искать другой пакет.
    В принципе, можешь обойтись без with, заменив его на try: ... finally: server.close()
    Ответ написан
  • Как распарсить запрос в Python?

    Vindicar
    @Vindicar
    RTFM!
    Ну я бы описал каждое составное условие как коллекцию "имя поля - условие, применяемое на поле".
    Но возможно, лучше как-то кардинально это решитью. Например, навесить теги на обрабатываемые объекты, и делать поиск по тегам.
    Ответ написан
  • Как сделать рассылку всем пользователям которые нажали /start?

    Vindicar
    @Vindicar
    RTFM!
    Проверь тип данных user. Можно тупо print(type(user)). Обычно БД в питоне возвращают каждую строку выдачи как кортеж, даже если в строке одно значение. В этом случае нужно будет сделать telegram_id = user[0]
    Ответ написан
  • Как правильно выводить COUNT?

    Vindicar
    @Vindicar
    RTFM!
    Поясню ответ Everything_is_bad выше: эта запись соответствует встроенному типу данных питона - кортеж (tuple). Ты должен уметь этот тип данных узнать, и знать как работать с ним (а также со списками и словарями) ДО того, как браться за ботов. Это азы, без понимания которых ты будешь спотыкаться на каждой мелочи.
    Ответ написан
  • Как создавать фреймы в неопределённом кол-ве?

    Vindicar
    @Vindicar
    RTFM!
    Простой вариант - складывай нужные объекты в список. Если что, можно сделать список кортежей.
    Чуть более сложный вариант - опиши класс, описывающий пару кнопка-label, и реализующий логику выбора файла, и складывай в список экземпляры этого класса.
    Ответ написан
    Комментировать
  • Как остановить поток while true нажатием горячих клавиш?

    Vindicar
    @Vindicar
    RTFM!
    Потому что is_pressed() проверяет, нажата ли клавиша прямо сейчас. С 99% вероятностью у тебя нажатие начнётся и закончится когда выполняется time.sleep(), потому что он долгий. А потому на момент выполнения is_pressed() клавиша уже будет отпущена.
    Проще всего будет заменить один долгий sleep() на цикл из коротких ожиданий и проверок, примерно по 0,1-0,2 секунды.
    Ответ написан
    Комментировать
  • Как решить module 'cv2' has no attribute 'TrackerCSRT_create'?

    Vindicar
    @Vindicar
    RTFM!
    Как ставил OpenCV? Там несколько пакетов. opencv-python содержит только основные возможности, а целый ряд вещей вынесен в opencv-contrib-python. Плюс ряд алгоритмов доступен не во всех версиях, так что выясни, начиная с какой версии поддерживается этот алгоритм, и какая версия стоит у тебя.
    Ответ написан
    Комментировать
  • Как сохранить файл, который скачивается автоматически при переходе по ссылке?

    Vindicar
    @Vindicar
    RTFM!
    через requests сохраняется html код страницы, где нет и намека на файл

    Вариант 1: не убедил сайт, что твой бот - это не бот. Добавляй заголовки - реферер, куки, юзер-агент и т.д. Можешь их прямо скопировать с браузера.
    Вариант 2: сайт редиректит на нужную ссылку через JS. Разбери код страницы, найди как формируется ссылка и научись её извлекать, а потом уже эту ссылку качай через requests.
    Ответ написан
    Комментировать
  • Как активировать код путем нажатия правой кнопки мыши (Python)?

    Vindicar
    @Vindicar
    RTFM!
    Нажатия правой кнопки мыши где?
    А вообще посмотри в сторону нестандартного модуля mouse (ставится через pip).
    Ответ написан
  • Disnake в команде temprole возникла ошибка, в чём здесь ошибка?

    Vindicar
    @Vindicar
    RTFM!
    Если коротко.
    "Object of type "None" is not subscriptable" - если при вызове команды не указан параметр времени, он будет None (так как ты указал значение None по умолчанию). Решения два.
    а) замени значение по умолчанию None на какое-то другое, например, "15m". Тогда, если срок не указан, то будет дан срок по умолчанию.
    б) Перед обращением к time проверяй, не None ли он. ЛЮБЫЕ обращения к переменной time допустимо производить, только если там не None.

    "t(time_letter)" - ты вызываешь некую функцию t. Судя по окружающему коду, она должна преобразовывать название интервала времени ("s", "m", "h" и т.п.) в длину этого интервала времени в секундах. "t" is unbound означает, то ты не объявил такую функцию в области видимости этого кода (например, выше по коду в том же файле). Эту функцию нужно объявить, тогда её можно будет использовать.

    Обе ошибки достаточно простые, если есть хоть какое-то знакомство с языком. А потому повторю актуальнейший совет: не учить язык по ботам. Боты - это НЕ просто. Начни с чего-то более простого.
    Ответ написан
  • Как вывести все элементы списка из массива списков json в Python?

    Vindicar
    @Vindicar
    RTFM!
    1. Перестаём путать списки и словари, чтобы не сбивать с толку ни себя, ни советчиков.
    2. Пишем функцию, которая проверяет один элемент внешнего списка на предмет "подходит-не подходит", и возвращает True если он подходит.
    3. Грузим JSON с помощью модуля json.
    4. Используем list(filter(...)), чтобы получить отфильтрованный список элементов, указав функцию из п.2 в качестве функции фильтра.
    5. Если нужны дополнительные операции, то перебираем полученный список, для каждого элемента выполняем нужное тебе действие.
    6. Сохраняем итог в файл с помощью всё того же модуля json, например.
    Ответ написан
    Комментировать
  • Как достать ссылки на страницы при парсинге?

    Vindicar
    @Vindicar
    RTFM!
    Вот ссылка в коде сайта:

    Как проверял, что она в коде сайта? Небось через браузер?

    Правило первое: при ошибке записывай в файл то, что тебе прислал сервер, для последущего анализа. Может, сервер понял, что твой бот - это бот, и там "уходи, противный" вместо ожидаемой тобой страницы. А может, там динамический сайт, с контентом, подгружаемым через JS.
    Ответ написан
    Комментировать
  • Что делать с ошибкой OperationalError: no such column?

    Vindicar
    @Vindicar
    RTFM!
    Блин, да когда же вы читать научитесь, а?
    Никогда не используй f-строки для формирования sql-запроса, это либо даёт невалидный SQL (как в твоём случае), либо оставляет лазейку для SQL-инъекции.
    Используй подстановку параметров. Про это буквально в каждом мануале по работе с БД пишут, но ведь читать - не модно.
    cursor.execute("INSERT INTO masseges (id, massege) VALUES (NULL, ?)", (text,) )

    Ну и да. Правильно пишется message, если речь о сообщениях.
    Ответ написан
    2 комментария
  • Почему не пaлучяется вывести принт в текстовый документ 111.txt?

    Vindicar
    @Vindicar
    RTFM!
    Как ты запускаешь скрипт?

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

    Альтернативно, ты можешь попробовать указать полный (абсолютный) путь к файлу при его открытии.
    Ответ написан
    Комментировать
  • Почему код работает не так как нужно?

    Vindicar
    @Vindicar
    RTFM!
    А почему он не должен этого делать? У тебя asd() объявлена, но нигде не упоминается и не вызывает, так что бот о ней ничего не знает.
    Ответ написан
  • Как оптимизировать алгоритм самонаведения ракеты?

    Vindicar
    @Vindicar
    RTFM!
    Уточню, velocity - это обычно вектор скорости, а speed - скалярная величина, модуль этого вектора.
    У тебя есть пара вариантов:
    а)
    MSL_VEL = (TGT_POS - MSL_POS).normalize() * MSL_SPD
    для ракеты, не знающей вектор скорости цели, а потому летящей без упреждения.
    б)
    MSL_VEL = (TGT_POS + TGT_VEL * GAME_TICK - MSL_POS).normalize() * MSL_SPD
    для ракеты с упреждением на один игровой тик.

    Если на нормализацию вектора не хватает CPU, то нужно выяснить почему.
    Ответ написан