この記事はBoostlogの翻訳記事です。
このチュートリアルでは、Pythonで簡単なDiscordBotを作成する方法を学びます。
Discordは、ゲーマーがターゲットのSkypeのようなサービスです。
Discordでは、複数のサーバーに参加することができます。
これらのサーバーには多くのbotがあることに気がつきました。
これらのbotは、音楽を演奏したり、簡単なチャットのモデレートまで、多くのことを行うことができます。
そんなbotに魅了されたので、Pythonを使って書くことにしました。
設定
初めにbotのアカウントを作成します。
DiscordAppに行き、新しいアプリを作成してください。
botに名前をつけ、プロフィール画像を貼ってください。
下にスクロールして「Create a Bot User」をクリックします。
完了したら、「secret bot token」を取得できます。
data:image/s3,"s3://crabby-images/28422/28422fdd99563e4ee7e4429b17c93d16f4925a48" alt="スクリーンショット 2018-05-09 18.41.42.png"
クリックして 「bot token」を表示することができます。
data:image/s3,"s3://crabby-images/749c5/749c527562f3ee46585192f32612a33ab18c002e" alt="スクリーンショット 2018-05-09 18.43.11.png"
botを乗っ取られるので、このtokenは誰にも共有しないでください。
(記事を書いた後、画像のtokenは変更します。)
コード
前提条件
Discord.py (rewrite)
discord.pyライブラリの書き換えバージョンをインストールします。
pipのdiscord.pyは管理されていないので、rewrite版のライブラリをインストールしてください。
$ python3 -m pip install -U https://github.com/Rapptz/discord.py/archive/rewrite.zip
使用しているdiscord.pyのバージョンの確認
>>> import discord
>>> discord.__version__
'1.0.0a'
botの作成に移りましょう。
import discord
from discord.ext import commands
ModuleNotFoundErrorまたはImportErrorを指定すると、discord.pyのインストールに問題が発生します。
bot = commands.Bot(command_prefix='$', description='A bot that greets the user back.')
command_prefixとは、コマンドを呼び出すために最初にメッセージの内容が含まなければならないものです。
@bot.event
async def on_ready():
print('Logged in as')
print(bot.user.name)
print(bot.user.id)
print('------')
on_ready()
はクライアントがDiscordから受信したデータの準備を完了したときに呼び出されます。
通常はbotのログインが成功した後に呼ばれます。
次に、botにいくつかの機能を追加しましょう。
@bot.command()
async def add(ctx, a: int, b: int):
await ctx.send(a+b)
@bot.command()
async def multiply(ctx, a: int, b: int):
await ctx.send(a*b)
@bot.command()
async def greet(ctx):
await ctx.send(":smiley: :wave: Hello, there!")
@bot.cmmands()
async def cat(ctx):
await ctx.send("https://media.giphy.com/media/JIX9t2j0ZTN9S/giphy.gif")
実行する前に、サーバーにbotを招待する必要があります。
このOAuth2のURLは、botの設定ページから生成できます。
DiscordAppに行き、botのプロフィールをクリックしてoAuth2のURLを生成してください。
data:image/s3,"s3://crabby-images/d1f44/d1f440007dabd1afa5e98a122d73a37b7a988072" alt="スクリーンショット 2018-05-10 14.13.05.png"
ここで、botに与える権限を決めます。
使用するために、メッセージを送信するための許可が必要です。
以下をコマンドラインで実行して、botを実行します。
$ python bot.py
data:image/s3,"s3://crabby-images/4e95b/4e95b2ce9fd11d732fc289f685f047342e5f98dc" alt="スクリーンショット 2018-05-10 14.13.28.png"
botを試して見ます。
data:image/s3,"s3://crabby-images/b7057/b7057a3be2561b7c0a6b2a84ecd6d0ce351d2650" alt="スクリーンショット 2018-05-10 14.14.01.png"
data:image/s3,"s3://crabby-images/be286/be286f254bb329cc9695afcd07703e7475cdf4a1" alt="スクリーンショット 2018-05-10 14.14.10.png"
DiscordBotを作る際に良いリファレンスがあります。
こちらを読むことをお勧めします。
Have an info command.
It should provide information about the bot such as what framework it is using and the used version, help command and, most importantly, who made it.
@bot.command()
async def info(ctx):
embed = discord.Embed(title="nice bot", description="Nicest bot there is ever.", color=0xeee657)
# give info about you here
embed.add_field(name="Author", value="<YOUR-USERNAME>")
# Shows the number of servers the bot is member of.
embed.add_field(name="Server count", value=f"{len(bot.guilds)}")
# give users a link to invite thsi bot to their server
embed.add_field(name="Invite", value="[Invite link](<insert your OAuth invitation link here>)")
await ctx.send(embed=embed)
data:image/s3,"s3://crabby-images/16df2/16df2d4046b19ff130e239853a897bd2a9d915b7" alt="スクリーンショット 2018-05-10 14.15.09.png"
The discord.py generates an help
command automatically.
So, to write our own, we would first have to remove the one given by it.
discord.pyは自動的にhelp
コマンドを生成します。
自分自身で書くために、はじめにこれを削除します。
bot.remove_command('help')
これでhelpコマンドを書くことができます。
ここではbotの使用法について説明します。
@bot.command()
async def help(ctx):
embed = discord.Embed(title="nice bot", description="A Very Nice bot. List of commands are:", color=0xeee657)
embed.add_field(name="$add X Y", value="Gives the addition of **X** and **Y**", inline=False)
embed.add_field(name="$multiply X Y", value="Gives the multiplication of **X** and **Y**", inline=False)
embed.add_field(name="$greet", value="Gives a nice greet message", inline=False)
embed.add_field(name="$cat", value="Gives a cute cat gif to lighten up the mood.", inline=False)
embed.add_field(name="$info", value="Gives a little info about the bot", inline=False)
embed.add_field(name="$help", value="Gives this message", inline=False)
await ctx.send(embed=embed)
data:image/s3,"s3://crabby-images/b8dcd/b8dcde2e2b57c890fd0078f1ff97c26f550034bd" alt="スクリーンショット 2018-05-10 14.15.57.png"
Pythonで書かれたDiscordBotを作成できました。
ホスティング
今のところは、botはスクリプトを実行するまでオンラインになっているだけです。
botを常に実行したい場合は、オンラインでホストする必要があります。
また、RaspberryPiなどでローカルにホストすることもできます。
ホスティングサービスは無料のもの(Heroku's Free Tier)から有料(Digital Ocean)のものもあります。
私は無料のHerokuでbotを走らせてますが、これまでどんな問題も発生してません。
ソースコード
import discord
from discord.ext import commands
bot = commands.Bot(command_prefix='$')
@bot.event
async def on_ready():
print('Logged in as')
print(bot.user.name)
print(bot.user.id)
print('------')
@bot.command()
async def add(ctx, a: int, b: int):
await ctx.send(a+b)
@bot.command()
async def multiply(ctx, a: int, b: int):
await ctx.send(a*b)
@bot.command()
async def greet(ctx):
await ctx.send(":smiley: :wave: Hello, there!")
@bot.command()
async def cat(ctx):
await ctx.send("https://media.giphy.com/media/JIX9t2j0ZTN9S/giphy.gif")
@bot.command()
async def info(ctx):
embed = discord.Embed(title="nice bot", description="Nicest bot there is ever.", color=0xeee657)
# give info about you here
embed.add_field(name="Author", value="<YOUR-USERNAME>")
# Shows the number of servers the bot is member of.
embed.add_field(name="Server count", value=f"{len(bot.guilds)}")
# give users a link to invite thsi bot to their server
embed.add_field(name="Invite", value="[Invite link](<insert your OAuth invitation link here>)")
await ctx.send(embed=embed)
bot.remove_command('help')
@bot.command()
async def help(ctx):
embed = discord.Embed(title="nice bot", description="A Very Nice bot. List of commands are:", color=0xeee657)
embed.add_field(name="$add X Y", value="Gives the addition of **X** and **Y**", inline=False)
embed.add_field(name="$multiply X Y", value="Gives the multiplication of **X** and **Y**", inline=False)
embed.add_field(name="$greet", value="Gives a nice greet message", inline=False)
embed.add_field(name="$cat", value="Gives a cute cat gif to lighten up the mood.", inline=False)
embed.add_field(name="$info", value="Gives a little info about the bot", inline=False)
embed.add_field(name="$help", value="Gives this message", inline=False)
await ctx.send(embed=embed)
bot.run('NDE0MzIyMDQ1MzA0OTYzMDcy.DWl2qw.nTxSDf9wIcf42te4uSCMuk2VDa0')