Ответы пользователя по тегу Discord
  • Почему не присваивается реакция в переменную?

    Vindicar
    @Vindicar
    RTFM!
    Ну во-первых, ты добавляешь реакцию к одному сообщению, а смотришь у другого.
    ctx.channel.last_message может и не совпадать с сообщением startMes, если за время простановки реакции в канал было отправлено ещё одно сообщение.
    Во-вторых, discord.py много чего кэширует. Список reactions может обновиться не сразу.
    В-третьих, а зачем тебе смотреть список реакций сразу после вывода сообщения? Вряд ли кто-то успеет проставить свою.
    Ответ написан
    Комментировать
  • Как редактировать сообщение бота в Discord // python?

    Vindicar
    @Vindicar
    RTFM!
    Если ты используешь discord.py, то примерно так
    1. Узнать id канала (он неизменен, его можно прописать в коде), получить его объект через метод бота .fetch_channel()
    2. Узнать id сообщения(он неизменен, его можно прописать в коде), получить объект сообщения через метод канала .fetch_message()
    3. Вызываешь метод .edit() сообщения.

    Читай документацию, там много интересного.
    Ответ написан
    Комментировать
  • Как получить список всех пользователей на сервере Discord?

    Vindicar
    @Vindicar
    RTFM!
    Клиент - это твой бот. Если почитать немножко поглубже, найдешь описание класса Bot
    Represents a discord bot.

    This class is a subclass of discord.Client and as a result anything that you can do with a discord.Client you can do with this bot.

    Очень частая ошибка - пытаться работать одновременно с экземпляром Client и экземпляром Bot. Это просто не нужно.
    Ответ написан
  • Как сделать чтобы при вводе команды писались все участники роли. discord.py?

    Vindicar
    @Vindicar
    RTFM!
    Ты документацию читал? Там нужная информация есть.
    А что касается задания роли - указываешь тип параметра команды discord.Role, и 90% дела сделано.
    Ответ написан
  • Как сделать сообщение бота ответом на команду?

    Vindicar
    @Vindicar
    RTFM!
    Может и слепой.
    Берешь свойство message у контекста, получаешь объект сообщения. У него есть метод reply().
    Ответ написан
    Комментировать
  • Что делать если при попытке выдачи роли через бота дискорд появляется ошибка?

    Vindicar
    @Vindicar
    RTFM!
    Что делать? Открыть глаза, прочитать ошибку, понять ошибку. Мыслить логически.
    await req(guild_id, user_id, role.id, reason=reason)
    AttributeError: 'NoneType' object has no attribute 'id'

    "У None нет атрибута id". Т.е. вместо некоего объекта с атрибутом id передали None.
    Смотрим на строку кода и ищем обращение к атрибуту id. Это role.id, т.е. вместо параметра роли в метод передали None.
    Смотрим выше, пока не найдём ссылку на строку не из discord.py.
    await author.add_roles(role)
    Т.е. твоя переменная role имеет значение None.
    Ищем эту строку в коде, потом смотрим выше откуда взялось role.
    role = guild.get_role(940997266100064316)
    Смотрим документацию на get_role().
    Returns the role or None if not found.

    Т.е. role может содержать None, если переданный id не соответствует роли в этом сервере.
    Вот тебе и ответ. Перепроверь id, который ты передаёшь в get_role().
    Ответ написан
    Комментировать
  • Как исправить ошибку с выдачей роли в дискорд боте пайтон?

    Vindicar
    @Vindicar
    RTFM!
    что еще за self.get_guild(), и почему нельзя взять guild из ctx?
    Сейчас discord.py ожидает, что self будет передана как параметр при вызвое команды пользователем.
    Ответ написан
    Комментировать
  • Нужна помощь с sqlite3, discord.py?

    Vindicar
    @Vindicar
    RTFM!
    В коде неправильного больше чем правильного...
    1. У тебя написано, что команда должна получить два параметра - text и id. Если id она должна найти сама, то его нужно убрать из параметров купить(). id нужно получить из ctx.author.id.
    2. Ты вообще пробовал обращаться к своей базе? Смотрел, что тебе возвращает fetchone()?
    По твоему запросу она вернёт либо кортеж с одним значением, либо None, если не было найдено ни одной подходящей строки.
    Ни то ни другое сравнивать непосредственно нельзя!
    Вытащи результат в переменные, проверь на None, а потом уже сравнивай нулевые элементы.
    3. Убери токен бота из тела вопроса.
    4. Советую cursor создавать внутри обработчика, во избежание заморочек с одновременным использованием.
    5. Советую указывать типы параметров в описании команды! discord.py обращает на них внимание, и пытается конвертировать входную строку.
    async def купить(ctx, text: str):
    6. Как уже было написано, execute() принимает вторым параметром КОРТЕЖ, пусть даже из одного элемента. А кортеж из одного элемента пишется как (item,).
    Ответ написан
  • Как вписать в дискорд бота команду по выдаче роли с удалением предыдущих ролей?

    Vindicar
    @Vindicar
    RTFM!
    Храни в БД сведения о наказанных пользователях + timestamp окончания срока наказания, и в отдельной таблице - о ролях, которые у них были забраны.
    Ответ написан
    Комментировать
  • Анимация из картинок в tkinter и асинхромная работа с discord, возможно ли это и как это сделать?

    Vindicar
    @Vindicar
    RTFM!
    Главная проблема: у любого GUI-приложения есть бесконечный цикл обработки оконных сообщений. У любого асинхронного приложения есть бесконечный цикл-реактор, который обрабатывает реакции на завершение асинхронных операций (в т.ч. ввода-вывода). Это два разных цикла, они друг о друге не знают, и в одном потоке может работать только один из них.

    Отсюда два решения.
    1. Плюнуть на Tkinter и использовать PyQT. Есть сторонняя библиотека pyqt-async, которая вроде как позволяет засунуть обработку оконных сообщений в цикл-реактор.
    2. Запустить в главном потоке цикл-реактор, а GUI (на базе любого фреймворка) создать и запустить во вспомогательном. Любые задачи для выполнения в главном потоке делать через asyncio.run_coroutine_threadsafe(). Любые модификации GUI делать, создавая статичный объект-описание операции над GUI и поместив его в очередь (Queue, например). Поток GUI должен периодически читать эту очередь, и вносить найденные там изменения. В ткинтере может помочь метод after(), наверно есть аналоги и в других фреймворках.
    Ответ написан
    Комментировать
  • Как заносить ники людей из дискорда (discord.py) в базу данных sqlite3?

    Vindicar
    @Vindicar
    RTFM!
    Во-первых, сама идея - плохая, так как ник можно менять. Используй числовой id пользователя вместо ника.
    Во-вторых, никогда не формируй текст запроса через форматирование строк. Используй подстановку параметров.
    Ответ написан
    Комментировать
  • Нужна с помощь с discord.py?

    Vindicar
    @Vindicar
    RTFM!
    f"SELECT id FROM userifo where id={member.id}
    Никогда так не делай.
    А вообще, что ты пытаешься сделать? Перебрать все сервера и занести их участников в БД?
    Во-первых, у класса Client (и у его наследника discord.ext.commands.Bot) есть свойство guilds. Это список отдельных серверов, можешь просто перебрать его for'ом.
    Во-вторых, в sqlite есть синтаксис INSERT ON CONFLICT UPDATE, который позволяет добавить запись или обновить её, если она уже существует, за один запрос а не за два.
    В-третьих, твой алгоритм перебора не сумеет обнаружить участников, покинувших сервер, так как они просто не появятся в списке участников.
    В-четвёртых, если ты не понимаешь, зачем в коде та или иная строка, тебе рано браться за написание ботов. Поучи сначала основы питона, почитай документацию на discord.py, потом вернёшься к теме. Сэкономишь много времени на вопросах.
    Ответ написан
    Комментировать
  • Есть ли наказание за радужные роли дискорд?

    Vindicar
    @Vindicar
    RTFM!
    Бота может вырубить за флуд, разве что. Да и вырвиглазно это.
    Ответ написан
    Комментировать
  • Как добавить парсер в дискорд бот?

    Vindicar
    @Vindicar
    RTFM!
    n = print(item['name'])
    В-первых, ничего не выводит куда?
    Во-вторых, print() выводит данные в стандартный вывод, обычно в консоль. В дискорд через неё ничего не послать.
    Во-третьих, print() всегда возвращает None. Так что n всегда будет None, и присваивание не имеет смысла.
    В-четвертых, почему не использовать нормальный обработчик команд из discord.ext.commands.Bot? Он тоже позволяет реагировать на сообщения, в придачу к остальным полезностям именно для бота. Это при условии, что ты хочешь именно реакцию на сообщение и не согласен обойтись обычной командой.
    В-пятых, если ты не уверен, что такое print(), почему ты пытаешься писать ботов?

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

    Vindicar
    @Vindicar
    RTFM!
    Документацию читал?
    1. Make sure you’re logged on to the Discord website.
    2. Navigate to the application page.
    3. Click on the bot you want to enable privileged intents for.
    4. Navigate to the bot tab on the left side of the screen. discord_bot_tab.png
    5. Scroll down to the “Privileged Gateway Intents” section and enable the ones you want. discord_privileged_intents.png
    Ответ написан
    1 комментарий
  • Почему я когда хочу замутить игрока я пишу например "-замутить @F1azy 1 тест" сообщение о муте игрока присылается только после того когда мут прошёл?

    Vindicar
    @Vindicar
    RTFM!
    Потому что ты приказал боту сделать именно так.
    await member.add_roles(muterole) # добавляешь роль
    await asyncio.sleep(time * 60) # ЖДЕШЬ
    await member.remove_roles(muterole) # удаляешь роль
    await channel.send(embed = emb) #отправляешь сообщение

    Он и делает, что сказано.
    Ответ написан
    Комментировать
  • В чём проблема? Как решить?

    Vindicar
    @Vindicar
    RTFM!
    bot = discord.ext.commands.Bot(command_prefix = "|");
    bot.run("ТОКЕН")
    client = discord.Client()
    client.run('ТОКЕН')

    Вот скажи, ЗАЧЕМ тебе и Client и Bot?
    Впрочем, догадываюсь. Читать документацию - это ведь для ламеров, а в видяшке написано @client, значит, нужен класс Client, и не волнует.
    class discord.ext.commands.Bot
    Represents a discord bot.
    This class is a subclass of discord.Client and as a result anything that you can do with a discord.Client you can do with this bot.

    Выделение моё.
    В итоге ты регистрируешь команды на одном клиенте, запускаешь совсем другого, и удивляешься, что ничего не работает.
    Про самописную обработку команд в on_message() комментировать не буду.
    Ответ написан
    Комментировать
  • Как выводить сообщение без остановки?

    Vindicar
    @Vindicar
    RTFM!
    Ну во-первых ты творишь какой-то колхоз. discord.py тащит как зависимость асинхронную aiohttp, а ты сначала используешь синхронный requests, а потом заворачиваешь его в асинхрон через ThreadPool, потом обратно заворачиваешь в синхронный код в main(), а потом этот main() хочешь использовать вместе с асинхронным кодом discord.py. Жесть.
    Вот не проще осилить изначально асинхронную библиотеку, которую и так и так придётся использовать?

    Далее, что за бредятина с while? Что, по-твоему, должен делать вызов on_ready() в цикле? Что еще за точки с запятыми в питоне?
    Ты делаешь чисто синхронный бесконечный цикл, естественно этот цикл не даёт асинхронному коду исполняться.

    Ну и до кучи зачем-то используешь discord.Client вместо discord.Bot.

    Даже базового знания того, как работает асинхронность в питоне, достаточно, чтобы набросать код вида:
    import asyncio
    import aiohttp
    import discord
    from discord.ext import commands
    client = commands.Bot(intents = discord.Intents.default())
    
    async def fetch():
        return ... # тут вытаскиваем данные с сайта через aiohttp и возвращаем в удобном нам виде
    
    async def display(results):
        global client
        pass  # тут выводишь результаты в дискорд, используя объект client
    
    async def cycle():
        while True:
            res = await fetch()  # обработку ошибок допиши сам
            await display(res)
            await asyncio.sleep(300)  # задержка в секундах
    
    cycle_task = None
    @client.ready
    async def on_ready():
        global cycle_task
        if cycle_task is None:  # событие ready может отрабатывать несколько раз, нам нужен только один.
            cycle_task = asyncio.get_event_loop().create_task(cycle())
        pass  # тут делаешь что тебе еще нужно по запуску бота
    
    # когда надо будет остановить цикл, вызови cycle_task.cancel()
    bot.run(TOKEN)  # запускаешь бота
    Ответ написан
    Комментировать