Discord py on member join не работает

Обновлено: 02.07.2024


Пользователи часто спрашивают, как создать бота в Дискорде и тем самым получить программу с необходимыми функциями. Сразу отметим, что достижение такой цели — непростая задача, а реализовать ее можно несколькими способами, к примеру, на основе discord.js, на Python или с помощью программы Discord Bot Maker.

Как создать Дискорд-бота на основе discord.js

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

Выполните следующие шаги:



  1. Введите название будущего бота Дискорд, к примеру, Music Bot.
  2. Перейдите на вкладку Bot, а после жмите на кнопку Add Bot.



Этих действий достаточно, чтобы создать бота Дискорд, после чего нужно его добавить на сервер с помощью OAuth2 URL-генератора. Сделайте следующие шаги:

  1. Переместитесь в раздел OAuth2 и выберите Bot в панели Scopes.


  1. Укажите необходимые разрешения для проигрывания музыки и чтения.
  2. Копируйте созданный URL и вставьте его в веб-проводник.
  3. Выберите сервер, куда нужно добавить URL.
  4. Жмите на кнопку авторизации (Authorize).



На следующем этапе нужно создать проект с применением терминала. Для этого создайте директорию и перейдите ее с помощью следующих команд — mkdir musicbot && cd musicbot. Далее сделайте следующее:

  1. Создайте модули проекта с применением nmp init.
  2. Ответьте на несколько вопросов, которые необходимы, чтобы создать бота в Дискорд.
  3. Сделайте два файла, где будет вестись работа — touch index.js && touch config.json.
  4. Откройте проект в редакторе, к примеру, с помощью VS Code с применением приказа code.
  5. Установите группу зависимостей, необходимых для дальнейшей работы — npm install discord.js ffmpeg-binaries opusscript ytdl-core –save.
  6. Продолжите создание файла на config.json. На этом этапе сохраните префикс и токен для бота.
  1. Войдите на портал создания Дискорд и копируйте токен из раздела Bot (жмите на кнопку Copy).

Теперь нужно создать код javascript. Для этого копируйте следующие зависимости:

const Discord = require(‘discord.js’);

const ytdl = require(‘ytdl-core’);

После этого нужно создать с применением токена клиент и логин.

const client = new Discord.Client();

Далее добавьте несколько listeners, которые выполняют console.log при пуске.

После этого начните работать с ботом Дискорд с применением node. Важно, чтобы вновь созданный Discord-бот был онлайн. В консоли появится Ready!. Команда — node index.js.

Задание команд для бота Дискорд

Теперь остается задать необходимые команды.

Чтобы Дискорд-бот мог читать, напишите функцию.

client.on(‘message’, async message =>

if (message.author.bot) return;

if (!message.content.startsWith(prefix)) return;

Далее проверьте команду, которую нужно активировать. Используйте следующие команды.

> else if (message.content.startsWith(`$skip`))

> else if (message.content.startsWith(`$stop`))

После получения списка команд, которые можно запустить, переходите к их созданию.

Добавление песен

Здесь нужна гильдия, песня и библиотека ytdl (должна быть установлена заранее). Сделайте map с названием очереди, где будут храниться песни.

const queue = new Map();

async function execute(message, serverQueue)

const args = message.content.split(‘ ‘);

const voiceChannel = message.member.voiceChannel;

if (!permissions.has(‘CONNECT’) || !permissions.has(‘SPEAK’))

Перейдите к получению данных о песне и сохраните ее в song. Для этого потребуется ytdl-библиотека, получающая данные по ютуб-ссылке.

const songInfo = await ytdl.getInfo(args[1]);

В раздел serverQueue, если он пустой, добавьте трек. В случае, когда serverQueue имеет параметр null, сделайте контракт.

// Creating the contract for our queue

// Setting the queue using our contract

// Pushing the song to our songs array

// Here we try to join the voicechat and save our connection into our object.

var connection = await voiceChannel.join();

// Calling the play function to start a song

// Printing the error message if the bot fails to join the voicechat

Проигрывание трека

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

function play(guild, song)

const serverQueue = queue.get(guild.id);

Если да, нужно уйти с голосового канала и удалить очередь.

Далее трек играет с применением URL и playStream.

const dispatcher = serverQueue.connection.playStream(ytdl(song.url))

// Deletes the finished song from the queue

// Calls the play function again with the next song

Здесь создается stream, а его URL передается адресу песни.

Пропуск трека

Здесь оформите завершение диспетчера, который был сделан в опции play. Такое действие необходимо, чтобы начал играть очередной трек.

function skip(message, serverQueue)

Здесь проверяется, есть ли пользователь в голосовом канале, и имеется ли трек для пропуска.

Остановка

Опция stop подразумевает очистку массива song, удаления очереди и выхода из чата.

Step 0


Вас перекинет на подобную страницу. Выберите раздел Applications. В этот момент вас попросят авторизоваться. Пройдите авторизацию если вы этого не сделали ранее.

Замечание: Если после авторизации у вас открылся Discord в браузере, просто вернитесь на пару страниц назад и опять выберите раздел Applications.


У вас появится окно, в которое необходимо вписать название вашего приложения. Жмём Create.


Перейдите в раздел Bot и добавьте бота Add Bot. В появившемся окне нажимаем Yes, do it! Должно появиться подобное окно, как ниже.


Окно после создания бота

Пролистайте страницу в самый низ и дайте боту права администратора. ВАЖНО! Выдавайте права администратора только на стадии разработки. После того как вы напишете бота, снимите данную галочку и укажите только необходимые для корректной работы бота права.


Установка прав доступа бота

Почти готово!

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


В появившихся окнах выбирайте следующие пункты.

Теперь переходим в браузер и переключаемся на вкладку OAuth2. Ставим галочку напротив пункта Bot, ниже в окне должна появиться ссылка, которую необходимо скопировать и вставить в новой вкладке браузера.

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

Step 1





результат работы команды hello


при отправке команды /add через пробел напишите два числа и бот пришлёт вам сумму этих чисел.


Discord bot on python: part 1 : 1 комментарий

Самая легкая, понятная и информативная инструкция по созданию бота! Спасибо большое!

Step 0


Вас перекинет на подобную страницу. Выберите раздел Applications. В этот момент вас попросят авторизоваться. Пройдите авторизацию если вы этого не сделали ранее.

Замечание: Если после авторизации у вас открылся Discord в браузере, просто вернитесь на пару страниц назад и опять выберите раздел Applications.


У вас появится окно, в которое необходимо вписать название вашего приложения. Жмём Create.


Перейдите в раздел Bot и добавьте бота Add Bot. В появившемся окне нажимаем Yes, do it! Должно появиться подобное окно, как ниже.


Окно после создания бота

Пролистайте страницу в самый низ и дайте боту права администратора. ВАЖНО! Выдавайте права администратора только на стадии разработки. После того как вы напишете бота, снимите данную галочку и укажите только необходимые для корректной работы бота права.


Установка прав доступа бота

Почти готово!

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


В появившихся окнах выбирайте следующие пункты.

Теперь переходим в браузер и переключаемся на вкладку OAuth2. Ставим галочку напротив пункта Bot, ниже в окне должна появиться ссылка, которую необходимо скопировать и вставить в новой вкладке браузера.

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

Step 1





результат работы команды hello


при отправке команды /add через пробел напишите два числа и бот пришлёт вам сумму этих чисел.


Discord bot on python: part 1 : 1 комментарий

Самая легкая, понятная и информативная инструкция по созданию бота! Спасибо большое!

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


Получение токена и Client ID для вашего бота

Для получения токена и ID бота небходимо создать свое приложение и в разделе General Information скопировать Client ID.


А в разделе настроек создать бота и скопировать его токен. Задача не сложная, думаю все с этим справятся.


Собственно пишем бота

Устанавливаем discord.py с помощью pip:


После успешной установки создаем файл bot.py, где будем писать бота.

Импортируем все необходимое:


Создаем переменную с вашим токеном, про который я писал выше:

Хотя еще рано, но если вы захотите залить вашего бота на какой-нибудь сервер, то стоить побеспокоится о безопасности вашего токена.

Создаем тело бота:


Для начала сделаем простенькую команду, аргумент которой бот будет просто пересылать:


И в конце запускаем бота с вашим токеном:


В итоге должно получится вот такое:

Теперь необходимо добавить бота на сервер. Сделать это можно с помощью ссылки:


Число необходимых прав можно получить в разделе настроек бота.

Теперь можно запускать бота:


После нескольких секунд, можно заметить его в сети:



Заключение

Вот так можно легко запустить у себя на сервере бота. Как можно заметить библиотека делает практически все за тебя и остается только добавлять свой функционал с использованием python. В следующий раз я покажу как следить за событиями, подключатся к голосовым каналам (избегая проблем с linux и Windows), использовать роли и права участников и другое.

Читайте также: