Discord bot 비망록 ①봇 작성편
소개
Discord bot를 만든 비망록
어떤 상황에서 Discord bot를 만들고 싶었기 때문에, bot 작성으로부터 다양한 액션의 비망록
slackbot 이외에도 손을 내고 싶었다
물품 쓰기는 다음과 같습니다
Discord란?
Discord(디스코드)란, ~~~ 음성 통화·VoIP 프리 소프트웨어이다.
(Wikipedia에서)
지금까지 Slack처럼 사용한 적이 여러 번있었습니다.
Slack에 봇이 있으니까 Discord도…
Discord bot를 만드는 방법
디스코드 개발자 에서 작성
응용 프로그램 페이지에서 새 응용 프로그램을 클릭
data:image/s3,"s3://crabby-images/d3e2f/d3e2fbfc409a1622f9727734e7db93a9ee8be4be" alt=""
봇 이름을 듣기 때문에 좋아하는 봇 이름을 붙인다.
Bot 페이지를 열고 Add Bot 버튼을 클릭합니다.
Yes, do it!도 클릭
data:image/s3,"s3://crabby-images/65538/655386767bacb660256bef7502b5bfda60c71844" alt=""
생성된 봇이 표시됨
아이콘과 이름도 변경 가능
TOKEN 이름을 복사하십시오.
data:image/s3,"s3://crabby-images/05c0d/05c0db59c048d8a8abd37e4b3dfbb34c9404e0d6" alt=""
OAuth2를 다음과 같이 설정
(일단 TEXT계는 모두 ON으로 해 보았다)
data:image/s3,"s3://crabby-images/d5a77/d5a77cc0bd49a30bfc5e6cf8af6465c6ddd3b300" alt=""
data:image/s3,"s3://crabby-images/4f7ba/4f7ba4dc27f0dff98e36480d13738c5a92e07117" alt=""
OAuth2 설정 화면의 URL에 접속하면 어디의 Discord 룸에 Bot를 초대할지 묻는다
정체가 끝나면 멋지게 봇이 방에 들어온다
data:image/s3,"s3://crabby-images/f7c35/f7c35db3e7df7d1bdbe8e2f04505b7636358937b" alt=""
모듈, 디렉토리 구조 등
모듈
모듈은 다음과 같습니다
필요한 경우 설치하십시오.
pip install discord # discordを使用する際に必要
디렉토리 구조
디렉토리 구조는 다음과 같습니다.
- dis_python
- img
- good.png
-dis_test.py
여러 가지를 만들어 보았습니다.
공식 씨
ぢs 아이 rd. py 씨 여러가지가 쓰여져 있습니다.
해보고 싶은 것을 철저히 조사하면 재미 있습니다.
프로그램
dis_test.pyimport discord
TOKEN = "BotのTOKENを張り付ける"
client = discord.Client()
GOOD_IMG = "./img/good.PNG"
### イベントハンドラ一覧 #################################################
# async def の後を変えるだけで実行されるイベンドが変わる
# メッセージ受信時に実行: on_message(message)
# Bot起動時に実行: on_ready(message)
# リアクション追加時に実行: on_reaction_add(reaction, user)
# 新規メンバー参加時に実行: on_member_join(member)
# ボイスチャンネル出入に実行: on_voice_state_update(member, before, after)
###################################################################
# bot起動時処理
@client.event
async def on_ready():
channel = client.get_channel(チャンネルIDを張り付ける)
await channel.send("やぁ!元気かい?")
# message を受け取ったとき
@client.event
async def on_message(message):
# 送り手がボットの場合、無視
if message.author.bot:
return
if message.content.startswith("こんにちは"):
await message.channel.send("こんにちは!")
if len(message.attachments) > 0:
await message.channel.send("何かファイルを送ったね???")
@client.event
async def on_reaction_add(reaction, user):
await reaction.message.channel.send('{}を押したね??'.format(reaction.emoji), file=discord.File(GOOD_IMG))
client.run(TOKEN)
세세한 설명은 다음 번에 정리하겠습니다.
조금 해설
TOKEN과 채널 ID는 자신이 사용하는 것을 사용하십시오.
채널 ID는 URL 맨 뒤의 '숫자 2'입니다.
://discordapp.com/channels/숫자들1/숫자들2
이벤트 핸들러 일람에는 사용할 것 같은 것을 정리하고 있습니다
특히 on_message ()는 잘 사용합니다.
출력 결과
명령줄
data:image/s3,"s3://crabby-images/9eac8/9eac83ddf2a010fff8fa36f87bb485b1b309df34" alt=""
bot와의 연극
data:image/s3,"s3://crabby-images/f8d09/f8d09a1d76850b694039492d00c215803c544ea6" alt=""
data:image/s3,"s3://crabby-images/fdfa6/fdfa67d44e4b2357476ade15e83280e9e18a3232" alt=""
우선 대략 정리해 보았다
문서에 관해서는 내용이 짙기 때문에 다음에 돌리고 싶습니다.
특히 on_message에서의 파일 조작 등이 의외로 번거로웠기 때문에 그 근처의 비망록을 (˘ω˘)
Reference
이 문제에 관하여(Discord bot 비망록 ①봇 작성편), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://qiita.com/str32/items/39283355e71240113e09
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
디스코드 개발자 에서 작성
응용 프로그램 페이지에서 새 응용 프로그램을 클릭
data:image/s3,"s3://crabby-images/d3e2f/d3e2fbfc409a1622f9727734e7db93a9ee8be4be" alt=""
봇 이름을 듣기 때문에 좋아하는 봇 이름을 붙인다.
Bot 페이지를 열고 Add Bot 버튼을 클릭합니다.
Yes, do it!도 클릭
data:image/s3,"s3://crabby-images/65538/655386767bacb660256bef7502b5bfda60c71844" alt=""
생성된 봇이 표시됨
아이콘과 이름도 변경 가능
TOKEN 이름을 복사하십시오.
data:image/s3,"s3://crabby-images/05c0d/05c0db59c048d8a8abd37e4b3dfbb34c9404e0d6" alt=""
OAuth2를 다음과 같이 설정
(일단 TEXT계는 모두 ON으로 해 보았다)
data:image/s3,"s3://crabby-images/d5a77/d5a77cc0bd49a30bfc5e6cf8af6465c6ddd3b300" alt=""
data:image/s3,"s3://crabby-images/4f7ba/4f7ba4dc27f0dff98e36480d13738c5a92e07117" alt=""
OAuth2 설정 화면의 URL에 접속하면 어디의 Discord 룸에 Bot를 초대할지 묻는다
정체가 끝나면 멋지게 봇이 방에 들어온다
data:image/s3,"s3://crabby-images/f7c35/f7c35db3e7df7d1bdbe8e2f04505b7636358937b" alt=""
모듈, 디렉토리 구조 등
모듈
모듈은 다음과 같습니다
필요한 경우 설치하십시오.
pip install discord # discordを使用する際に必要
디렉토리 구조
디렉토리 구조는 다음과 같습니다.
- dis_python
- img
- good.png
-dis_test.py
여러 가지를 만들어 보았습니다.
공식 씨
ぢs 아이 rd. py 씨 여러가지가 쓰여져 있습니다.
해보고 싶은 것을 철저히 조사하면 재미 있습니다.
프로그램
dis_test.pyimport discord
TOKEN = "BotのTOKENを張り付ける"
client = discord.Client()
GOOD_IMG = "./img/good.PNG"
### イベントハンドラ一覧 #################################################
# async def の後を変えるだけで実行されるイベンドが変わる
# メッセージ受信時に実行: on_message(message)
# Bot起動時に実行: on_ready(message)
# リアクション追加時に実行: on_reaction_add(reaction, user)
# 新規メンバー参加時に実行: on_member_join(member)
# ボイスチャンネル出入に実行: on_voice_state_update(member, before, after)
###################################################################
# bot起動時処理
@client.event
async def on_ready():
channel = client.get_channel(チャンネルIDを張り付ける)
await channel.send("やぁ!元気かい?")
# message を受け取ったとき
@client.event
async def on_message(message):
# 送り手がボットの場合、無視
if message.author.bot:
return
if message.content.startswith("こんにちは"):
await message.channel.send("こんにちは!")
if len(message.attachments) > 0:
await message.channel.send("何かファイルを送ったね???")
@client.event
async def on_reaction_add(reaction, user):
await reaction.message.channel.send('{}を押したね??'.format(reaction.emoji), file=discord.File(GOOD_IMG))
client.run(TOKEN)
세세한 설명은 다음 번에 정리하겠습니다.
조금 해설
TOKEN과 채널 ID는 자신이 사용하는 것을 사용하십시오.
채널 ID는 URL 맨 뒤의 '숫자 2'입니다.
://discordapp.com/channels/숫자들1/숫자들2
이벤트 핸들러 일람에는 사용할 것 같은 것을 정리하고 있습니다
특히 on_message ()는 잘 사용합니다.
출력 결과
명령줄
data:image/s3,"s3://crabby-images/9eac8/9eac83ddf2a010fff8fa36f87bb485b1b309df34" alt=""
bot와의 연극
data:image/s3,"s3://crabby-images/f8d09/f8d09a1d76850b694039492d00c215803c544ea6" alt=""
data:image/s3,"s3://crabby-images/fdfa6/fdfa67d44e4b2357476ade15e83280e9e18a3232" alt=""
우선 대략 정리해 보았다
문서에 관해서는 내용이 짙기 때문에 다음에 돌리고 싶습니다.
특히 on_message에서의 파일 조작 등이 의외로 번거로웠기 때문에 그 근처의 비망록을 (˘ω˘)
Reference
이 문제에 관하여(Discord bot 비망록 ①봇 작성편), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://qiita.com/str32/items/39283355e71240113e09
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
pip install discord # discordを使用する際に必要
- dis_python
- img
- good.png
-dis_test.py
공식 씨
ぢs 아이 rd. py 씨 여러가지가 쓰여져 있습니다.
해보고 싶은 것을 철저히 조사하면 재미 있습니다.
프로그램
dis_test.py
import discord
TOKEN = "BotのTOKENを張り付ける"
client = discord.Client()
GOOD_IMG = "./img/good.PNG"
### イベントハンドラ一覧 #################################################
# async def の後を変えるだけで実行されるイベンドが変わる
# メッセージ受信時に実行: on_message(message)
# Bot起動時に実行: on_ready(message)
# リアクション追加時に実行: on_reaction_add(reaction, user)
# 新規メンバー参加時に実行: on_member_join(member)
# ボイスチャンネル出入に実行: on_voice_state_update(member, before, after)
###################################################################
# bot起動時処理
@client.event
async def on_ready():
channel = client.get_channel(チャンネルIDを張り付ける)
await channel.send("やぁ!元気かい?")
# message を受け取ったとき
@client.event
async def on_message(message):
# 送り手がボットの場合、無視
if message.author.bot:
return
if message.content.startswith("こんにちは"):
await message.channel.send("こんにちは!")
if len(message.attachments) > 0:
await message.channel.send("何かファイルを送ったね???")
@client.event
async def on_reaction_add(reaction, user):
await reaction.message.channel.send('{}を押したね??'.format(reaction.emoji), file=discord.File(GOOD_IMG))
client.run(TOKEN)
세세한 설명은 다음 번에 정리하겠습니다.
조금 해설
TOKEN과 채널 ID는 자신이 사용하는 것을 사용하십시오.
채널 ID는 URL 맨 뒤의 '숫자 2'입니다.
://discordapp.com/channels/숫자들1/숫자들2
이벤트 핸들러 일람에는 사용할 것 같은 것을 정리하고 있습니다
특히 on_message ()는 잘 사용합니다.
출력 결과
명령줄
data:image/s3,"s3://crabby-images/9eac8/9eac83ddf2a010fff8fa36f87bb485b1b309df34" alt=""
bot와의 연극
data:image/s3,"s3://crabby-images/f8d09/f8d09a1d76850b694039492d00c215803c544ea6" alt=""
data:image/s3,"s3://crabby-images/fdfa6/fdfa67d44e4b2357476ade15e83280e9e18a3232" alt=""
우선 대략 정리해 보았다
문서에 관해서는 내용이 짙기 때문에 다음에 돌리고 싶습니다.
특히 on_message에서의 파일 조작 등이 의외로 번거로웠기 때문에 그 근처의 비망록을 (˘ω˘)
Reference
이 문제에 관하여(Discord bot 비망록 ①봇 작성편), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/str32/items/39283355e71240113e09텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)