Как создать бота в Дискорде
Всем привет! Сегодня поговорим о том как сделать, написать и запустить своего бота в популярной бесплатной программе для общения Discord. Итак, поехали!
Как сделать Дискорд-бота на базе discord.js
На практике API Discord дает собой благоприятный инструмент, позволяющий сделать, а после чего применить бота. С его поддержкой просто создать ассистента для заключения различных задач, а дальше задать важный комплект команд.
Для примера разглядим артельный метод сотворения бота для музыки. При верном раскладе он может проигрывать, пропускать и одергивать музыкальные файлы. В его функциях еще есть помощь очереди на проигрывание мелодии.
Исполните надлежащие шаги.
Войдите на вебсайт discord.com/developers/applications/.
Нажимайте на кнопку New Application.
Введите заглавие грядущего бота Дискорд, к примеру, Music Bot.
Перейдите на вкладку Bot, а впоследствии нажимайте на кнопку Add Bot.
Данных поступков довольно, дабы сделать бота Дискорд, впоследствии чего надо его прибавить на сервер с поддержкой OAuth2 URL-генератора. Устройте надлежащие шаги.
Переместитесь в раздел OAuth2 и изберите Bot в панели Scopes.
Укажите нужные разрешения для проигрывания музыки и чтения.
Копируйте разработанный URL и воткните его в веб-проводник.
Изберите сервер, куда надо прибавить URL.
Нажимайте на кнопку авторизации (Authorize).
На надлежащем рубеже надо сделать план с использованием терминала.
Для сего смоделируйте директорию и перейдите ее с поддержкой надлежащих команд — mkdir musicbot && cd musicbot. Дальше устройте надлежащее.
Смоделируйте модули плана с использованием nmp init.
Ответьте на некоторое количество вопросов, которые выжны, дабы сделать бота в Дискорд.
Устройте 2 файла, где станет вестись работа — touch index.js && touch config.json.
Откройте план в редакторе, к примеру, с поддержкой VS Code с использованием приказа code.
Установите группу зависимостей, важных для последующей работы — npm install discord.js ffmpeg-binaries opusscript ytdl-core –save.
Продолжите создание файла на config.json. На данном рубеже сбережете префикс и токен для бота.
{
«prefix»: «!»,
«token»: «your-toke»
}
Войдите на портал создания Дискорд и копируйте токен из раздела Bot (жмите на кнопку Copy).
Теперь нужно создать код javascript. Для этого копируйте следующие зависимости:
const Discord = require(‘discord.js’);
const {
prefix,
token,
} = require(‘./config.json’);
const ytdl = require(‘ytdl-core’);
После этого нужно создать с применением токена клиент и логин.
const client = new Discord.Client();
client.login(token);
Далее добавьте несколько listeners, которые выполняют console.log при пуске.
client.once(‘ready’, () => {
console.log(‘Ready!’);
});
client.once(‘reconnecting’, () => {
console.log(‘Reconnecting!’);
});
client.once(‘disconnect’, () => {
console.log(‘Disconnect!’);
});
После этого начните работать с ботом Дискорд с применением node. Важно, чтобы вновь созданный Discord-бот был онлайн. В консоли появится Ready!. Команда — node index.js.
Задание команд для бота Дискорд
Теперь остается задать необходимые команды.
Для чтения сообщений
Чтобы Дискорд-бот мог читать, напишите функцию.
client.on(‘message’, async message => {
}
Далее сделайте listener для massage-события, получите сообщение и сохраните его в massage. Если информация пришла от бота Дискорд, игнорируйте ее. Выполните проверку с помощью следующей команды.
if (message.author.bot) return;
Если сообщение вернулось, значит, его смог создать бот. Теперь проверьте, с какого префикса оно начинается.
if (!message.content.startsWith(prefix)) return;
Далее проверьте команду, которую нужно активировать. Используйте следующие команды.
if (message.content.startsWith(`${prefix}play`)) {
execute(message, serverQueue);
return;
} else if (message.content.startsWith(`${prefix}skip`)) {
skip(message, serverQueue);
return;
} else if (message.content.startsWith(`${prefix}stop`)) {
stop(message, serverQueue);
return;
} else {
message.channel.send(‘You need to enter a valid command!’)
}
После получения списка команд, которые можно запустить, переходите к их созданию.
Добавление песен
Здесь нужна гильдия, песня и библиотека ytdl (должна быть установлена заранее). Сделайте map с названием очереди, где будут храниться песни.
const queue = new Map();
Теперь создайте async0-функцию с названием execute и убедитесь, находится ли пользователь в чате, и имеется ли необходимое разрешение. При его отсутствии пишете сообщение об ошибке.
async function execute(message, serverQueue) {
const args = message.content.split(‘ ‘);
const voiceChannel = message.member.voiceChannel;
if (!voiceChannel) return message.channel.send(‘You need to be in a voice channel to play music!’);
const permissions = voiceChannel.permissionsFor(message.client.user);
if (!permissions.has(‘CONNECT’) || !permissions.has(‘SPEAK’)) {
return message.channel.send(‘I need the permissions to join and speak in your voice channel!’);
}
}
Перейдите к получению данных о песне и сохраните ее в song. Для этого потребуется ytdl-библиотека, получающая данные по ютуб-ссылке.
const songInfo = await ytdl.getInfo(args[1]);
const song = {
title: songInfo.title,
url: songInfo.video_url,
};
Необходимые данные сохраняются в song. Теперь нужно создать контракт, обеспечивающий добавление в очередь.
Проверьте факт определения serverQueue (проигрывание музыки), а после отправьте сообщение о достижении результата.
Если это не удалось сделать, нужно его создать и соединиться с голосовым каналом и начать играть песню.
if (!serverQueue) {
}else {
serverQueue.songs.push(song);
console.log(serverQueue.songs);
return message.channel.send(`${song.title} has been added to the queue!`);
}
В раздел serverQueue, если он пустой, добавьте трек. В случае, когда serverQueue имеет параметр null, сделайте контракт.
// Creating the contract for our queue
const queueContruct = {
textChannel: message.channel,
voiceChannel: voiceChannel,
connection: null,
songs: [],
volume: 5,
playing: true,
};
// Setting the queue using our contract
queue.set(message.guild.id, queueContruct);
// Pushing the song to our songs array
queueContruct.songs.push(song);
try {
// Here we try to join the voicechat and save our connection into our object.
var connection = await voiceChannel.join();
queueContruct.connection = connection;
// Calling the play function to start a song
play(message.guild, queueContruct.songs[0]);
} catch (err) {
// Printing the error message if the bot fails to join the voicechat
console.log(err);
queue.delete(message.guild.id);
return message.channel.send(err);
}
Проигрывание трека
Теперь нужно создать опцию play для бота Дискорд с параметрами гильдия и песня, а также проверкой объекта song.
function play(guild, song) {
const serverQueue = queue.get(guild.id);
if (!song) {
serverQueue.voiceChannel.leave();
queue.delete(guild.id);
return;
}
}
Если да, нужно уйти с голосового канала и удалить очередь.
Далее трек играет с применением URL и playStream.
const dispatcher = serverQueue.connection.playStream(ytdl(song.url))
.on(‘end’, () => {
console.log(‘Music ended!’);
// Deletes the finished song from the queue
serverQueue.songs.shift();
// Calls the play function again with the next song
play(guild, serverQueue.songs[0]);
})
.on(‘error’, error => {
console.error(error);
});
dispatcher.setVolumeLogarithmic(serverQueue.volume / 5);
Здесь создается stream, а его URL передается адресу песни.
Пропуск трека
Здесь оформите завершение диспетчера, который был сделан в опции play. Такое действие необходимо, чтобы начал играть очередной трек.
function skip(message, serverQueue) {
if (!message.member.voiceChannel) return message.channel.send(‘You have to be in a voice channel to stop the music!’);
if (!serverQueue) return message.channel.send(‘There is no song that I could skip!’);
serverQueue.connection.dispatcher.end();
}
Здесь проверяется, есть ли пользователь в голосовом канале, и имеется ли трек для пропуска.
Остановка
Опция stop подразумевает очистку массива song, удаления очереди и выхода из чата.
function stop(message, serverQueue) {
if (!message.member.voiceChannel) return message.channel.send(‘You have to be in a voice channel to stop the music!’);
serverQueue.songs = [];
serverQueue.connection.dispatcher.end();
}
Полный код бота для Дискорд
const Discord = require(‘discord.js’);
const {
prefix,
token,
} = require(‘./config.json’);
const ytdl = require(‘ytdl-core’);
const client = new Discord.Client();
const queue = new Map();
client.once(‘ready’, () => {
console.log(‘Ready!’);
});
client.once(‘reconnecting’, () => {
console.log(‘Reconnecting!’);
});
client.once(‘disconnect’, () => {
console.log(‘Disconnect!’);
});
client.on(‘message’, async message => {
if (message.author.bot) return;
if (!message.content.startsWith(prefix)) return;
const serverQueue = queue.get(message.guild.id);
if (message.content.startsWith(`${prefix}play`)) {
execute(message, serverQueue);
return;
} else if (message.content.startsWith(`${prefix}skip`)) {
skip(message, serverQueue);
return;
} else if (message.content.startsWith(`${prefix}stop`)) {
stop(message, serverQueue);
return;
} else {
message.channel.send(‘You need to enter a valid command!’)
}
});
async function execute(message, serverQueue) {
const args = message.content.split(‘ ‘);
const voiceChannel = message.member.voiceChannel;
if (!voiceChannel) return message.channel.send(‘You need to be in a voice channel to play music!’);
const permissions = voiceChannel.permissionsFor(message.client.user);
if (!permissions.has(‘CONNECT’) || !permissions.has(‘SPEAK’)) {
return message.channel.send(‘I need the permissions to join and speak in your voice channel!’);
}
const songInfo = await ytdl.getInfo(args[1]);
const song = {
title: songInfo.title,
url: songInfo.video_url,
};
if (!serverQueue) {
const queueContruct = {
textChannel: message.channel,
voiceChannel: voiceChannel,
connection: null,
songs: [],
volume: 5,
playing: true,
};
queue.set(message.guild.id, queueContruct);
queueContruct.songs.push(song);
try {
var connection = await voiceChannel.join();
queueContruct.connection = connection;
play(message.guild, queueContruct.songs[0]);
} catch (err) {
console.log(err);
queue.delete(message.guild.id);
return message.channel.send(err);
}
} else {
serverQueue.songs.push(song);
console.log(serverQueue.songs);
return message.channel.send(`${song.title} has been added to the queue!`);
}
}
function skip(message, serverQueue) {
if (!message.member.voiceChannel) return message.channel.send(‘You have to be in a voice channel to stop the music!’);
if (!serverQueue) return message.channel.send(‘There is no song that I could skip!’);
serverQueue.connection.dispatcher.end();
}
function stop(message, serverQueue) {
if (!message.member.voiceChannel) return message.channel.send(‘You have to be in a voice channel to stop the music!’);
serverQueue.songs = [];
serverQueue.connection.dispatcher.end();
}
function play(guild, song) {
const serverQueue = queue.get(guild.id);
if (!song) {
serverQueue.voiceChannel.leave();
queue.delete(guild.id);
return;
}
const dispatcher = serverQueue.connection.playStream(ytdl(song.url))
.on(‘end’, () => {
console.log(‘Music ended!’);
serverQueue.songs.shift();
play(guild, serverQueue.songs[0]);
})
.on(‘error’, error => {
console.error(error);
});
dispatcher.setVolumeLogarithmic(serverQueue.volume / 5);
}
client.login(token);
Как сделать бота в Дискорд на Python
Ещё раз метод — устроить Дискорд бота на Python. Артельный метод поступков грядущий.
Установите текстовый редактор.
Подготовьте Python 3.4.2+ и Pip3 (менеджер пакетов, важный для установки библиотек).
Смоделируйте бессодержательный файл с заглавием, к примеру, chatbot.py.
Откройте его с поддержкой текстового редактора и воткните код. Для его написания нужно обладать языком Python.
Образчик кода — gist.github.com/Tetraquark/911eb07052be10f0bb1323adb4056f86.
Поменяйте смысл переменной DISCORD_BOT_TOKEN, где надо сберечь токен бота.
Для получения инфы перейдите по ссылке discord.com/developers/applications, изберите необходимый бот Дискорд или же смоделируйте свежий, а впоследствии нажимайте на clich to reveal, где раскроется токен приложения.
Занести его в переменную DISCORD_BOT_TOKEN.
Сбережете файл и запустите бот Дискорд.
Для выполнения обозначенной повыше работы нужно владеть конкретным набором познаний.
Использование Discord Bot Maker
Как вариант, возможно сделать бота с поддержкой Discord Bot Maker. Это мощнейший инструмент, позволяющий устроить ассистента, умеющего отправлять файлы, генерировать и отправлять сообщения, манипулировать эмодзи, редактировать изображения и т. д.
Дабы сделать Дискорд-бота, устройте надлежащее.
Скачайте и установите утилиту.
Нажимайте на кнопку сотворения бота.
Установите нужные команды.
Сбережете и запустите bot для Дискорд
Процесс сотворения инстинктивно понятен, в следствие этого не станем становиться на нем подробнее.
Выводы
Ныне вы понимаете, как устроить собственного бота Discord, и собственно что понадобится для заключения задачки. Для сего надо владеть конкретные способности программирования или, как вариант, применить Discord Bot Maker.
В случае если у вас нет бесполезного времени, чем какого-либо другого скачать готового ассистента и воспользоваться его вероятностями
Рейтинг:
(голосов:1)
Предыдущая статья: Как пользоваться Дискордом на телефоне
Следующая статья: Как удалить аккаунт в Discord
Следующая статья: Как удалить аккаунт в Discord
Не пропустите похожие инструкции:
Комментариев пока еще нет. Вы можете стать первым!
Популярное
Авторизация
Добавить комментарий!