Как получить сообщение discord py
Перейти к содержимому

Как получить сообщение discord py

  • автор:

Discord py, прочитать сообщение пользователя

суть такова. Человек отправляет сообщение, к примеру "4". Затем бот записывает это значение в переменную, и далее спрашивает, ваша ставка? Далее ему пишут ставку, и опять же добавляет это значение в переменную. Я написал такой код

Ошибка выдается, вроде -"content не содержится. " Как мне получить это сообщение? Перепробовал много вариантов, ничего не помогло Видел что реализуют через @client_event async def on_message, но тогда он будет на каждую цифру отвечать, а мне нужно чтобы запускался только через !Казино, спасибо

Постараюсь понятно объяснить. Для того, чтобы совершить ожидание, можете воспользоваться функцией wait_for и записать его в переменную, с которой потом можно делать то, что хочется.

Ниже привожу пример кода:

0xdb's user avatar

Попробуй уместить это в одну команду, типа "Казино 4" и если что проверку на значение сделать типа такой:

Надеюсь, я вас правильно понял. Пользователь пишет команду со ставкой к примеру 1000:

!Казино 1000

Тогда это будет выглядеть примерно так:

Прочитать про функцию wait_for можно в документации.

jillstr's user avatar

Дизайн сайта / логотип © 2023 Stack Exchange Inc; пользовательские материалы лицензированы в соответствии с CC BY-SA . rev 2023.7.31.43551

Нажимая «Принять все файлы cookie» вы соглашаетесь, что Stack Exchange может хранить файлы cookie на вашем устройстве и раскрывать информацию в соответствии с нашей Политикой в отношении файлов cookie.

Discord.py Как вывести копию сообщения по ID?

Как отправить сообщения в чат по ID чата — discord.py rewrite?
Здраствуйте, вот у меня есть код по которому в должно отправляться сообщения в канал который указан.

Nodemailer, node-imap как создать копию сообщения в отправленных
Я сделала отправку сообщений с почты mail.ru через nodemailer, но заметила, что отправленные.

Отправка сообщения в Discord
Есть у кого идеи как можно отправить сообщение в дискорд? Может кто-то уже нашёл решение. Мне.

Плагин на голосовые сообщения Discord
Я нашел плагин который позволяет отправлять голосовые сообщения. Сейчас он пересталработать и.

Лучший ответСообщение было отмечено TonyPY как решение

Решение

Изменить цвет текста сообщения в Discord
Я делаю бота для дискорда, использую библиотеку Discord.js, мне нужно, чтобы бот при определённой.

Discord.py почему отправляет лишние сообщения?
Я пишу своего бота для дискорд использую библиотеку Discord.py. Я сделал команду /clear которая.

Оповещение в консоль при отправке сообщения ботом Discord
Как мне сделать, чтобы когда пользователю отправлялось сообщение в лс, в консоль писалось кому.

Как залить бутлоадер в китайскую копию arduino nano v3.0(CH340) через копию UNO
Пришли 2 контроллера, китацские копии arduino nano 3 и UNO. Обе на CH340. Драйвера встали.

Включить Discord.Intents для Discord бота
Доброго времени суток, уважаемые Форумчане. Возникла следующая трудность не могу никак понять как.

Работа с голосовыми каналами в Discord (Discord.Net v 2.0.1)
Интересует вопрос о вызове аудиопотока в Discord и выгрузке в этот аудиопоток музыки. Попытки.

Discord bot на Discord.Net
Вот не как не могу понять где ошибка ? using System; using System.Threading.Tasks; using.

How do i read message content in discord.py?

The following example will do what you want., Talent Recruit tech talent & build your employer brand , Word or expression to describe the feeling of nostalgia for a place that you used to like, but not any more, and are eager to leave behind again , Dynamic array implementation using C++

The following example will do what you want.

Answer by Keenan Mercado

Answer by Ryker McKenzie

There are many variables we could want to track from a server’s message history. But, to keep it simple, we’ll only be looking at when the messages were sent, who sent them, and the content of the message itself. And, to do that, we create a Data Frame containing one column for each.,To do so, we use the on_message() asynchronous function from the discord.py library, which runs every time a new message is sent. Then, we check if the message author is the bot itself, and, if not, whether the message starts with whatever string we define as our command call, which in this case I set to “_”.,If the message does start with the command call, I like to split it’s content and then save the first element into a ‘command’ variable and the rest into a list of parameters. But since we’ll be making the bot read whichever channel we call the command on, that part is optional.,In this day and age, applications that make use of text analysis are everywhere from your typical e-mail spam filter to chatbots capable of making enough sense out of messages that they can even respond to them.

Answer by Westley Bryant

Read-only list of messages the connected client has cached.,message (Message) – The deleted message.,message (Message) – The current message.,The emojis that the connected client has.

Answer by Kieran Wise

In this repository All GitHub ↵ Jump to ↵ , I have shown the entire traceback, if possible., I have searched the open issues for duplicates., I have removed my token from display, if visible.

Answer by Lennon Trejo

How can I get it to print whatever text the user responds with?,Currently this is what it prints, rather than the users text string.,Can someone explain to me in the correct terms why this worked?

Как получить сообщение discord py

суть такова. Человек отправляет сообщение, к примеру "4". Затем бот записывает это значение в переменную, и далее спрашивает, ваша ставка? Далее ему пишут ставку, и опять же добавляет это значение в переменную. Я написал такой код

Ошибка выдается, вроде -"content не содержится. " Как мне получить это сообщение? Перепробовал много вариантов, ничего не помогло Видел что реализуют через @client_event async def on_message, но тогда он будет на каждую цифру отвечать, а мне нужно чтобы запускался только через !Казино, спасибо

Постараюсь понятно объяснить. Для того, чтобы совершить ожидание, можете воспользоваться функцией wait_for и записать его в переменную, с которой потом можно делать то, что хочется.

Ниже привожу пример кода:

0xdb's user avatar

Попробуй уместить это в одну команду, типа "Казино 4" и если что проверку на значение сделать типа такой:

Надеюсь, я вас правильно понял. Пользователь пишет команду со ставкой к примеру 1000:

!Казино 1000

Тогда это будет выглядеть примерно так:

Прочитать про функцию wait_for можно в документации.

jillstr's user avatar

Дизайн сайта / логотип © 2023 Stack Exchange Inc; пользовательские материалы лицензированы в соответствии с CC BY-SA . rev 2023.6.13.43492

Нажимая «Принять все файлы cookie» вы соглашаетесь, что Stack Exchange может хранить файлы cookie на вашем устройстве и раскрывать информацию в соответствии с нашей Политикой в отношении файлов cookie.

Name already in use

discord-py-guide / discord-py.md

  • Go to file T
  • Go to line L
  • Copy path
  • Copy permalink

1 contributor

Users who have contributed to this file
  • Open with Desktop
  • View raw
  • Copy raw contents Copy raw contents

Copy raw contents

Copy raw contents

Руководство по использованию библиотеки discord-py

Здесь вы можете почитать об основах, которые необходимо понимать, чтобы грамотно работать с библиотекой и не задавать вопросов, касающихся самых базовых вещей

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

Прежде чем начать.

Прежде чем приступать к работе с ботом, я сразу рекомендую зайти на страницу вашего бота и включить намерения ( intents , подробнее). Для этого зайдите в раздел приложений и выберите вашего бота. Затем, слева, на вкладке «Bot»

Бот

Включите параметры PRESENCE INTENT и SERVER MEMBERS INTENT

введите сюда описание изображения

После этого выдайте намерения в коде при инициализации бота

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

Начало работы с ботом и discord-py

Бот, которого вы создали на странице приложений, является аккаунтом дискорда, который по сути является таким же пользовательским аккаунтом, как и ваш, но с атрибутом bot и некоторыми ограничениями. Чтобы бот начал что-то делать, нужно создать его в коде и прописать логику.

Для начала рассмотрим виды ботов, которые предоставляет библиотека:

    — фактически, самый базовый бот, на котором основаны другие. Умеет обрабатывать события по типу получения сообщений on_message() , установки реакции on_raw_reaction_add() и другие. — тот же discord.Client , только умеет находить в сообщениях и обрабатывать отдельные команды, которые начинаются с какого-либо префикса, например !test — про этого бота ничего сказать не могу, так как ни разу не использовал. Насколько мне известно, он нужен в тех случаях, когда вы планируете задать боту кучу разных комманд, событий и организовать все это в один отдельный класс.

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

Если помимо того, что я написал выше, вы хотите добавить еще и обработку команд по типу !ban <@User> , !play <Ссылка на видео с YouTube> , !погода и т.п., то использовать надо именно discord.ext.commands.Bot .

Теперь, когда вы определились с ботом можно наконец-то приступить к написанию кода.

Для начала подключим библиотеку.

На данном этапе я настоятельно рекомендую ознакомиться с руководством по использованию документации, так как на эту самую документацию я буду ссылаться очень часто и без ее использования вы вряд ли напишете что-то самостоятельно и будете постоянно спрашивать как реализовать ту или иную функцию.

В случае, если вы хотите использовать discord.ext.commands.Bot , я бы сразу отдельно подключил еще и этот пакет

Теперь создадим объект бота, который будет обрабатывать события и команды:

Из документации видим, что единственным обязательным аргументом при создании экземпляра класса является command_prefix .

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

Помимо этого, выдадим боту намерения ( intents ), инструкция по настройке которых была в начале.

В качестве префикса команды укажем ! , намерения нужно выдавать именно те, которые вы будете использовать, но на первое время можно выдать все, то есть discord.Intents.all()

Если у вас discord.ext.commands.Bot :

Если у вас discord.Client , то префикс указывать не нужно (класс не принимает такого аргумента):

Основные обработчики событий

Теперь у нас есть объект bot , для которого нужно написать логику взаимодействия.

В качестве обработчиков событий используются асинхронные ( async ) функции ( def ), помеченные декоратором @bot.event , где bot — название объекта вашего бота. Функция должна иметь название, строго как в документации — иначе событие просто не будет обработано.

Если коротко, то все, что делает декоратор @bot.event — это помещает написанную вами функцию в другую функцию из библиотеки discord , которая, в свою очередь, передает вашей функции какие-либо параметры. Поэтому, если не пометить функцию декоратором, discord не обратит на нее внимание и она не будет вызвана.

async def on_ready()

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

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

Выглядеть это будет вот так:

async def on_message(message)

Добавим обработчик сообщений, чтобы получать вызов функции каждый раз, когда bot получает сообщение в ЛС или на сервере.

В списке событий находим событие on_message(message) , которое принимает обязательный аргумент message . Этот аргумент имеет тип discord.Message из которого вы можете получить текст сообщения, а также объекты автора сообщения, сервер, канал, вложения, реакции, упоминания, ссылку на сообщение и много чего еще

Здесь вы можете прописать любую логику взаимодействия. Хоть даже удалять все только что переданные обработчиком сообщения (главное чтобы у бота были на то права). Самое главное — задать функции аргумент, который будет принимать объект сообщения. Вы можете назвать его как хотите, например даже так: async def on_message(собщение) , главное чтобы он был.

Если аргумент не указать, то при вызове события нового сообщения, discord-py отправит в функцию on_message() аргумент, содержащий объект сообщения, но получит ошибку о том, что указанная функция не принимает аргументов и ничего работать не будет. Это равноценно созданию функции, которая должна считать сумму 2 переданных в виде аргументов числа, но при этом она не принимает их.

По аналогии с примерами, приведенными выше, можно создать обработчик любого другого события, предствленного в discord-py . Главное, чтобы совпадало название и принимаемые аргументы.

Примеры других часто используемых событий:

on_raw_reaction_add(payload) , on_raw_reaction_remove(payload) — события добавления и удаления реакции с сообщения, соответствено. Из объекта payload вы можете получить сервер, сообщения и прочую инфу

on_member_join(member) , on_member_remove(member) — события подключения и выхода участника с сервера, в качестве аргумента принимает объект участника из которого можно получить всю информацию о пользователе.

Остальное вы можете найти в списке событий.

У вас уже есть объект бота и, вероятно, обработчики событий. Теперь бота нужно запустить.

При помощи токена, который нужно скопировать на странице бота, в разделе приложений вы можете авторизоваться в аккаунте бота.

Для этого у объекта bot нужно вызвать функцию run() :

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

Бот будет выполнять работу до дех пор, пока вы не завершите выполнение кода. Это означает, что если вы закроете консольное окно программы, то бот перестанет работать и обрабатывать какие-либо события.

Чтобы бот работал без вашего участия, его можно поставить на хостинг — тогда он будет постоянно запущен на удаленном сервере, а не на вашем устройстве. Например, можно использовать бесплатный (уже не бесплатный) хостинг Heroku. В интернете есть куча разных туториалов по настройке. Возможно, когда-нибудь здесь появится ссылка на мой ��

В итоге должен получиться примерно такой код, посмотреть который можно здесь.

Данный бот выводит сообщение при успешном запуске, а также подробную информацию о каждом полученном сообщении.

Для этого примера достаточно было бы простого бота discord.Client , так как он обрабатывает только события. Но я наперед прописал в коде бота discord.ext.commands.Bot , так как дальше в этот код мы будем добавлять обработку команд.

Обработка отдельных команд

Данный раздел содержит информацию об устаревших в дискорде prefix-командах ( !command / >command / $command и т.п.). На данный момент актуально создавать именно slash-команды ( /command ), которые интегрируются в дискорд и позволяют более комфортно разделять аргументы и добавлять к ним описание.

Так или иначе, руководство по slash-командам подразумевает знание материала по работе с prefix-командами. Поэтому прежде чем переходить к slash-командам, я рекомендую ознакомиться с материалом ниже.

Напоминаю, что для работы с командами, в качестве бота нужно использовать объект discord.ext.commands.Bot , а не discord.Client ! Не забудьте также про префикс

Команды бота, как и обработчики событий, являются асинхронными функциями ( async def ).

Чтобы discord-py обнаружил команду в коде, функцию нужно пометить декоратором @bot.command() , где bot — название объекта вашего бота.

Скобки в декораторе @bot.command() обязательны, в отличии от @bot.event , так как декторатор discord.ext.commands.Command() принимает необязательные аргументы. Без скобок декоратор корректно работать не будет. *Подробнее про декораторы можно почитать выше

В отличии от обработчиков событий, функцию можно назвать как захочется — название функции станет названием команды.

Любая функция, являющаяся командой, должна принимать обязательный аргумент ctx (можно назвать как угодно). Аргумент является контекстом ( discord.ext.commands.Context ) выполнения команды, из которого можно получить сервер, автора, сообщение, канал и др. информацию. При вызове команды, Контекст в функцию передает библиотека discord-py .

Перед созданием первой команды

Для начала, если у вас в коде есть обработчик событий on_message() , его нужно немного доработать.

Из документации видим, что у объекта пользователя ( discord.User ) есть свойство bot , имеющее тип bool . Значит, если свойство имеет значение True — пользователь является ботом, иначе — не является)

Допишем условие, чтобы сообщения от любых ботов (включая нашего) игнорировались. Это часто делается для того, чтобы другие боты не могли спамить вызовами команд, обработка которых сначала проходит через on_message() , ведь любая команда в дискорде по сути является просто сообщением.

Для этого, кстати, в on_message() нужно добавить еще одну строку await bot.process_commands(message) , которую можно найти в списке методов объекта discord.ext.commands.Bot . Метод принимает в качестве аргумента сообщение с типом discord.Message и нужен для того, чтобы проверять, являестя ли сообщение командой. Многие, забыв добавить эту строку, потом не понимают, почему их бот игнорирует команды (подробный разбор проблемы)

Ключевое слово return завершает выполнение функции, то есть код, который идет дальше, так или иначе не будет выполнен.

Создание первой команды

Создадим команду с названием test , при вызове которой бот будет отвечать в чат «Успешный тест!»:

Результат:

image

Реализацию такой команды можно было бы сделать через обычного бота discord.Client прямо в on_message() , проверяя, наличие префикса и конкретного названия команды. Однако при большом количестве команд запихивать все в одну функцию не очень хорошо, да и не удобно разделять аргументы, про которые, кстати, можно почитать далее.

*Почитать подробнее, почему не стоит делать команды через on_message() можно здесь

Для создания нескольких названий одной команды можно передать в декоратор @bot.command() аргумент aliases , принимающий список ( list ) или кортеж ( tuple ) с названиями команды. При этом самого названия функции там быть не должно.

Работа с аргументами команды

Предположим, вам нужно при вызове функции принять от пользователя число , значение типа bool и участника сервера discord.Member

image

Чтобы принять эти параматры, нужно указать их в качестве аргументов функции, которая используется в качестве команды:

Поскольку Python — язык с динамической типизацией, по умолчанию все полученные значения принимают строковый тип str , так как фактически были получены из строки ( str ), содержащей текст сообщения.

Тогда

  • number будет равно ’16’
  • boolean будет равно ‘True’
  • member будет равно ‘<@!239863351063144451>’

То есть из number нельзя будет вычесть число, boolean == True примет значение False , а member просто примет строку, содержащую форму упоминания пользователя.

Вместо того, чтобы вручную выполнять приведение типов ( number = int(number) , boolean = bool(boolean) и т.д.), можно сразу же явно указать тип аргумента функции:

И вот теперь уже все будет работать корректно. Помимо discord.Member можно указать любой другой тип библиотеки discord-py .

Из объекта member , например, можно получить id ( member.id ), ссылку на аватар ( member.avatar_url ) и другую информацию, которую можно найти в документации по объекту discord.Member .

Получить весь текст как один аргумент

В случае, когда вам в качестве аргумента нужен весь текст команды, можно использовать оператор * :

image

text будет иметь тип str и значение ‘это тестовый текст для проверки функции’

Если сделать так:

Также можно сначала получить несколько отдельных слов, а уже потом оставшийся текст:

  • first_word будет иметь тип str и значение ‘это’
  • second_word будет иметь тип str и значение ‘тестовый’
  • other_text будет иметь тип str и значение ‘текст для проверки функции’

Если смешать все команды из базового руководства в один код, то должно получиться что-то такое.

Данной информации должно хватить для понимания базовых вещей, таких как работа с документацией, создание prefix-команд, работа с обработчиками событий и т.д.

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

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