Задать вопрос
  • Из-за чего не выполняются действия?

    Vindicar
    @Vindicar
    RTFM!
    > user_id: Value "Amogus" is not snowflake.
    > user = await client.fetchUser(message.username);

    Если не обращать внимание на упоротую терминологию, я подозреваю что fetchUser() требует ID пользователя (для дискорда это длинное число), а не ник.
    Но это просто догадка.
    Ответ написан
    Комментировать
  • Как парсить cmd окно?

    Vindicar
    @Vindicar
    RTFM!
    Вариант 1. Заставить программу вывести данные в файл (как показал Hemul GM), затем прочитать этот файл.
    Вариант 2. Запустить программу самому через модуль subprocess. Он позволяет перехватить стандартный вывод процесса (т.е. вывод в консоль) и вернуть его содержимое в виде строки.
    Вариант 3. Раз уж в целевой программе есть сетевая поддержка, можно попробовать получить информацию через локальное соединение. Но нужно иметь представление о протоколе обмена (что нужно послать, чтобы запросить данные, и как интерпретировать ответ). Само соединение обеспечит модуль socket.
    Ответ написан
    Комментировать
  • Как можно сделать бонус раз в 24 часа?

    Vindicar
    @Vindicar
    RTFM!
    Фиксируешь время нажатия на кнопку.
    Выбираешь из базы значение предыдущего времени по id пользотеля запросом SELECT.

    Если значения нет, человек пишет в первый раз, заносим значение времени и id пользователя в базу запросом INSERT. Отправляем сообщение о бонусе.

    Если значение есть, и разница между ним и текущим временем более 24 часов, человек может получить бонус. Обновляем значение в базе запросом UPDATE и отправляем сообщение о бонусе.

    Если значение есть, и разница менее 24 часов, отправляем сообщение с оставшимся до следующего бонуса временем.
    Ответ написан
  • Как открыть другой исполняемый файл .py по кнопке?

    Vindicar
    @Vindicar
    RTFM!
    Потому что у тебя в вызываемом файле делается повторная инициализация приложения.
    Весь этот вот код
    app = QtWidgets.QApplication([])
    application = X() #где X - имя класса формы
    application.show()
    
    sys.exit(app.exec())

    выполняется как при прямом запуске файла, так и при его импорте.

    Есть два решения:
    а) убрать код инициализации из вспомогательных файлов, оставить его ТОЛЬКО в главном файле.
    б) если позарез нужно, чтобы вспомогательные файлы можно было запускать сами по себе без главного, то заверни этот код в конструкцию вида
    if __name__ == '__main__':
        #тут код, который будет выполняться
        #ТОЛЬКО если файл запущен сам по себе
        #и не будет выполняться, если этот файл импортируют
    Ответ написан
    5 комментариев
  • Как сделать текстовую игру в стиле бота в телеграмме на языке python?

    Vindicar
    @Vindicar
    RTFM!
    Учи, что такое конечные автоматы, и как их реализовывать. По сути, это тебе даст необходимую базу для реализации игры. Каждый сюжетный шаг будет состоянием, а действия игрока - переходами.

    Есть несколько способов их реализации, хорошо подумай, какой удобнее. Например, вариант с матрицей переходов будет работать плохо.
    Ответ написан
    Комментировать
  • Как cделать доступ к команде только для меня?

    Vindicar
    @Vindicar
    RTFM!
    Если "только для меня" = "только для владельца бота", то discord.ext.commands.is_owner(). Можно использовать как декоратор для обработчика команды.
    Ответ написан
    Комментировать
  • Как открыть exe file как архив?

    Vindicar
    @Vindicar
    RTFM!
    Для начала, что за архив? ZIP? Или RAR? RAR питон из коробки не умеет.
    Далее, самораспаковывающийся архив - это EXE, к которому тупо дописан архив. Если знаешь, как выглядит заголовок архива (в частности сигнатуру), то можно просканировать файл, найти сигнатуру, отмотать указатель файла на неё, и уже тогда отдавать файл ZIP-объекту.
    Ответ написан
    Комментировать
  • Проблема сортировки с SQLite 3 на Discord.py Хочу узнать из за чего не работает?

    Vindicar
    @Vindicar
    RTFM!
    А на койхрен ты создаешь embed внутри цикла?
    По-моему, тут проблема не в sqlite и не в дискорде.
    Ответ написан
    Комментировать
  • Как управлять консольным приложением через python?

    Vindicar
    @Vindicar
    RTFM!
    Ответ написан
    Комментировать
  • Как сделать чтобы к серверу можно было подключаться через определенный домен или это невозможно?

    Vindicar
    @Vindicar
    RTFM!
    Что значит "только через определённый домен"?
    Т.е. чтобы нельзя было подключиться, уже зная IP сервера, но не зная домена?
    Сомневаюсь. В HTTP протоколе передаётся имя сервера в заголовках, в HTTPS оно передаётся сначала через SNI, потом в заголовках, а вот в ShadowSocks... они не так давно вообще выкинули анализ расширения SNI. Так что скорее всего ShadowSocks по-барабану как юзер узнал IP - через DNS или ещё как.

    И главное, зачем? Что за сценарий этого требует?
    Ответ написан
    Комментировать
  • Как лучше сделать функцию прибавления +30 в бд, так чтобы при 2 пользователях не вис код, и не ждал окончания цикла?

    Vindicar
    @Vindicar
    RTFM!
    Учи, как работает асинхронное программирование.
    Если на пальцах: всякий раз, когда ты делаешь await чтототам, выполнение асинхронной функции (вроде обработчика события) приостанавливается, и передаётся другой.
    А вот код в промежутке между await вызовами (ну или началом-концом функции) выполняется непрерывно, и занимает поток управления. Пока этот код выполняется, остальной бот стоит!
    Теперь посмотри что у тебя:
    while (True):
                user.balance += user.s9 * 30
                time.sleep(30)
                user.save()

    time.sleep() понятия не имеет про асинхронность, и не отдаёт управление другим асинхронным функциям. Поэтому пока она выполняется, остальной бот стоит.
    Да, даже для одного пользователя.

    Как минимум, нужно исправить две вещи.
    1. используй await asyncio.sleep() вместо time.sleep(). asyncio.sleep() знает про асинхронность, и приостановит функцию с передачей управления, т.е. бот сможет делать что-то ещё пока эта функция ждёт.
    2. while (True) - это не тру. Предусмотри код выхода из цикла! Или по максимальному числу итераций, или по команде, или по смене статуса пользователя... или по всему вышеперечисленному.
    Ответ написан
    Комментировать
  • Как создать универсальную функцию для "производства" массивов объектов?

    Vindicar
    @Vindicar
    RTFM!
    Что тут сказать, начинайте с азов ООП, потом с азов Питона!
    create(10,Test1_1())
    Вы передаёте в функцию create результат вызова класса Test1_1() - т.е. один его экземпляр. Если хотите передать сам класс, скобки нужно опустить:
    create(10,Test1_1)
    И тогда уже в функции будете делать вызов переданного класса, а точнее, любого вызываемого (callable) объекта-фабрики.
    Ответ написан
    Комментировать
  • Как запретить лайкать?

    Vindicar
    @Vindicar
    RTFM!
    База данных есть, я надеюсь?
    Лайк - это классическая связь многие-ко-многим между постами и юзерами.
    Т.е. помимо таблицы постов и таблицы юзеров делаешь связную таблицу из двух полей - id поста и id юзера. Если в ней есть запись - юзер лайкнул пост. Тогда можно
    а) проверять заранее, есть ли такая запись, и показывать "вы уже лайкнули"
    б) игнорировать повторные лайки, если они всё-таки придут. Просто сделай пару юзер-пост ключом
    в) как бонус - можно посчитать количество лайков посту и выбрать что лайкнул конкретный юзер.
    Ответ написан
    Комментировать
  • Как сделать так чтобы бот discord писал другому юзеру, когда он нажимает на реакцию?

    Vindicar
    @Vindicar
    RTFM!
    Судя по тегам discord и python, хотите использовать discord.py?
    В таком случае, нужно обрабатывать событие на простановку реакции, добыть id юзера, который её проставил, отправить сообщение этом юзеру по его id.

    Самые азы работы с библиотекой тут.
    Ответ написан
    Комментировать
  • Как запустить определенный код в другом потоке?

    Vindicar
    @Vindicar
    RTFM!
    Модуль threading в помощь.
    Кроме того, стоит запоминать, было ли найдено лицо на предыдущем кадре. Если на предыдущем не было, а на текущем есть, и если поток не активен, запускаем поток.
    Ответ написан
    Комментировать
  • Как найти несколько минимальных чисел в матрице?

    Vindicar
    @Vindicar
    RTFM!
    Легко. При обходе матрицы формируешь список индексов, где встречался минимум. Тогда:
    а) если число больше минимума, не делаем ничего
    б) если число равно минимуму, вносим его индексы в список
    в) если число меньше минимума, очищаем список. Потом вносим его индексы в список.
    Ответ написан
    Комментировать
  • Как можно обратиться к локальной переменной?

    Vindicar
    @Vindicar
    RTFM!
    Лучше так не делать от слова совсем.
    Либо пусть ваша функция возвращает это значение, либо сделайте её методом в классе, а локальную переменную замените на поле класса.
    Ответ написан
    Комментировать
  • Как решить олимпиадную задачу python?

    Vindicar
    @Vindicar
    RTFM!
    Я бы подошёл так: при каком r сможет общаться напрямую та или иная пара антенн?
    Это даст тебе конечное множество из N*(N-1)/2 значений r, в которое будет входить ответ.
    А дальше сортируешь это множество по возрастанию, и для каждого r проверяешь, смогут ли общаться все антенны.
    Для этого берешь множесто антенн, в котором сначала содержится только антенна 1.
    Итеративно ищешь все антенны, которые не в этом множестве, но которые могут общаться с антеннами в множестве, и добавляешь их в множество. И так пока находишь хотя бы одну антенну, подходящую под эти условия. (Тут есть простор для оптимизаций, подумай.)
    Если после этого размер множества равен N, то в нём все антенны, и все они могут общаться друг с другом.
    Если размер меньше N, то часть антенн недостижима, нужно брать следующее большее значение r.
    Ответ написан
    Комментировать
  • Как можно заменить from module import * для однострочного кода Python?

    Vindicar
    @Vindicar
    RTFM!
    Открою страшную тайну:
    d = globals() # или locals() если нужна локальная область видимости
    d['x'] = 1
    print(x) #выведет 1


    Но зачем?
    Ответ написан
    5 комментариев
  • Как решить проблему динамического изменения данных во вложенном списке в python?

    Vindicar
    @Vindicar
    RTFM!
    a = []
    b = []
    b.append(a)
    b.append(a)
    a.append(1)
    print(b)
    #выведет [[1], [1]]

    Иными словами, список хранит не копию другого списка, а ссылку. Если вам нужна копия - сделайте её явно вызовом метода .copy() у списка.
    Ответ написан
    Комментировать