質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.31%
Discord

Discordは、ゲーマー向けのボイスチャットアプリです。チャット・通話がブラウザ上で利用可能で、個人専用サーバーも開設できます。通話中でも音楽を流したり、PC画面を共有できるなど多機能な点が特徴です。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

1回答

1318閲覧

discordのテキストチャンネル内のスレッドの情報を取得したいが記述方法がわからない

ella

総合スコア0

Discord

Discordは、ゲーマー向けのボイスチャットアプリです。チャット・通話がブラウザ上で利用可能で、個人専用サーバーも開設できます。通話中でも音楽を流したり、PC画面を共有できるなど多機能な点が特徴です。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2023/06/26 04:34

実現したいこと

discordのテキストチャンネル内のスレッドの情報を取得し、
そのスレッド内の発言者と発言数のデータをcsvに出力するプログラムを作成したい

前提

discordの各テキストチャンネルやスレッドなど、チャンネルやスレッド毎に誰がどの程度発言しているか
把握したいと思っています。

テキストチャンネルの情報を取得し、発言者と発言数は取得できるのですが、テキストチャンネルのなかのスレッドの
情報が取得できずに困っています。

発生している問題・エラーメッセージ

該当のソースコード

# 各チャンネルのメッセージを取得して統計情報を収集します for channel in guild.channels: if isinstance(channel, discord.TextChannel): #print(f"Processing channel: {channel.name}") # メッセージを取得して統計情報を収集します async for message in channel.history(limit=None): if message.author.bot: continue # ボットの発言は無視します # メッセージの日付が指定した月と一致する場合にのみ処理を行います if message.created_at.strftime("%Y-%m") == month: # 発言者の名前を取得します author_name = str(message.author) # Counterオブジェクトを初期化します if channel.id not in channel_stats: channel_stats[channel.id] = Counter() # 発言者のカウントを増やします channel_stats[channel.id][author_name] += 1 if isinstance(channel, discord.Thread): async for message in channel.history(limit=None):

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

この回答はGPT-4による自動生成回答です

以下のようにコードを修正して、テキストチャンネル内のスレッドを取得し、スレッド内の発言者と発言数をカウントできるようにしました。

python

1import discord 2from collections import Counter 3import csv 4 5# 各チャンネルのメッセージを取得して統計情報を収集します 6for channel in guild.channels: 7 if isinstance(channel, discord.TextChannel): 8 #print(f"Processing channel: {channel.name}") 9 10 # メッセージを取得して統計情報を収集します 11 async for message in channel.history(limit=None): 12 if message.author.bot: 13 continue # ボットの発言は無視します 14 15 # メッセージの日付が指定した月と一致する場合にのみ処理を行います 16 if message.created_at.strftime("%Y-%m") == month: 17 18 # 発言者の名前を取得します 19 author_name = str(message.author) 20 21 # Counterオブジェクトを初期化します 22 if channel.id not in channel_stats: 23 channel_stats[channel.id] = Counter() 24 25 # 発言者のカウントを増やします 26 channel_stats[channel.id][author_name] += 1 27 28 # テキストチャンネル内のスレッドを取得します 29 async for thread in channel.threads: 30 if isinstance(thread, discord.Thread): 31 # スレッド内のメッセージを取得して統計情報を収集します 32 async for message in thread.history(limit=None): 33 if message.author.bot: 34 continue # ボットの発言は無視します 35 36 # メッセージの日付が指定した月と一致する場合にのみ処理を行います 37 if message.created_at.strftime("%Y-%m") == month: 38 39 # 発言者の名前を取得します 40 author_name = str(message.author) 41 42 # Counterオブジェクトを初期化します 43 if thread.id not in channel_stats: 44 channel_stats[thread.id] = Counter() 45 46 # 発言者のカウントを増やします 47 channel_stats[thread.id][author_name] += 1 48 49# 統計情報をCSVファイルに出力します 50with open("output.csv", "w", newline="", encoding="utf-8") as csvfile: 51 writer = csv.writer(csvfile) 52 writer.writerow(["Channel ID", "Author", "Message Count"]) 53 54 for channel_id, stats in channel_stats.items(): 55 for author, count in stats.items(): 56 writer.writerow([channel_id, author, count])

このコードは、テキストチャンネル内のスレッドを取得し、スレッド内の発言者と発言数をカウントし、結果をCSVファイルに出力します。ただし、このコードはdiscord.pyのバージョン2.0以降で動作します。バージョン1.7以前の場合は、スレッドの取得方法が異なりますので、適切な方法で修正してください。

投稿2023/06/26 04:34

teratail-ai

Powered by GPT-4

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ella

2023/06/26 04:47

discord.pyのバージョン2.0以降で動作させていますが、 async for thread in channel.threads: ^^^^^^^^^^^^^^^ AttributeError: 'CategoryChannel' object has no attribute 'threads' エラーとなります...
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.31%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問