0

0

Discord.py:监听并响应用户状态变化

DDD

DDD

发布时间:2025-10-01 11:57:43

|

1014人浏览过

|

来源于php中文网

原创

Discord.py:监听并响应用户状态变化

本教程详细指导如何在Discord.py中检测用户状态变化并发送通知。我们将重点介绍使用on_member_update事件来捕捉用户在线状态、活动状态等更新,并通过比较前后状态来识别变化。文章涵盖了必要的Intents配置、事件处理逻辑、获取目标频道的方法,并提供了一个完整的Python代码示例,帮助你构建一个能够实时响应用户状态更新的Discord机器人。

理解 Discord.py 事件与 Intents

在discord.py中,监听机器人所在服务器内成员的事件是构建互动功能的基础。对于用户状态变化,许多开发者可能会想到on_presence_update事件。然而,需要明确的是,on_presence_update事件已被弃用或其功能已整合到其他事件中。目前,处理成员信息更新(包括状态变化)的推荐事件是on_member_update(before: discord.member, after: discord.member)。

为了让机器人能够接收到成员状态相关的事件,你必须在初始化机器人时启用特定的Intents(意图)。Intents是Discord API用来控制机器人接收哪些事件的机制,以优化资源使用并提高安全性。对于成员状态变化,至少需要启用discord.Intents.members和discord.Intents.presences。

  • discord.Intents.members: 允许机器人接收成员加入/离开、成员角色更新等事件。
  • discord.Intents.presences: 允许机器人接收成员的在线状态(如在线、离线、空闲、请勿打扰)和活动状态(如正在玩游戏、正在听音乐)更新。

在Discord开发者门户中,你也需要在你的机器人应用设置页面(Bot选项卡下)手动启用“PRESENCE INTENT”和“SERVER MEMBERS INTENT”。

核心逻辑:检测用户状态变化

on_member_update事件在成员的任何可观察属性发生变化时触发,包括其昵称、角色、以及最重要的——在线状态(status)和活动(activity)。该事件接收两个discord.Member对象作为参数:before和after。

  • before: 成员在更新前的状态。
  • after: 成员在更新后的状态。

要检测用户状态是否发生变化,我们只需比较before.status和after.status。discord.Status是一个枚举类型,包含online、offline、idle、dnd(请勿打扰)等值。

知识画家
知识画家

AI交互知识生成引擎,一句话生成知识视频、动画和应用

下载
import discord

# 确保在Discord开发者门户中启用了PRESENCE INTENT和SERVER MEMBERS INTENT
intents = discord.Intents.default()
intents.members = True  # 启用成员意图
intents.presences = True # 启用存在意图 (用于检测状态变化)

client = discord.Client(intents=intents)

TARGET_CHANNEL_ID = 123456789012345678  # 替换为你要发送消息的频道ID
TARGET_MEMBER_ID = 987654321098765432 # 可选:如果你只想追踪特定用户,替换为该用户ID

@client.event
async def on_ready():
    print(f'机器人已登录为 {client.user}')

@client.event
async def on_member_update(before: discord.Member, after: discord.Member):
    # 可选:如果你只想追踪特定用户
    # if after.id != TARGET_MEMBER_ID:
    #     return

    # 检查用户在线状态是否发生变化
    if before.status != after.status:
        print(f'{after.display_name} 的状态从 {before.status} 变为 {after.status}')

        # 获取目标频道
        target_channel = client.get_channel(TARGET_CHANNEL_ID)
        if target_channel:
            await target_channel.send(
                f'**{after.display_name}** 的状态更新了!\n'
                f'从 `{before.status.name}` 变为 `{after.status.name}`.'
            )
        else:
            print(f'错误:未找到ID为 {TARGET_CHANNEL_ID} 的频道。')

# 替换为你的机器人Token
client.run('YOUR_BOT_TOKEN_HERE')

发送通知消息

在检测到状态变化后,通常需要向特定频道发送通知。

  1. 获取目标频道: 可以使用client.get_channel(channel_id)方法通过频道的ID来获取频道对象。频道ID是唯一的数字标识符,可以在Discord客户端中通过开启开发者模式并右键点击频道来复制。
  2. 发送消息: 获取到频道对象后,使用await channel.send("你的消息内容")即可发送消息。

注意事项

  1. Intents 配置: 务必在代码中和Discord开发者门户中同时启用PRESENCE INTENT和SERVER MEMBERS INTENT。如果未启用,on_member_update事件可能不会被触发,或者不会包含状态信息。
  2. 频道 ID: 确保TARGET_CHANNEL_ID是正确的,并且机器人有权限在该频道发送消息。如果频道ID不正确或机器人没有权限,target_channel将为None,或send方法会抛出discord.Forbidden异常。
  3. 性能考虑: on_member_update事件在服务器中任何成员的任何相关属性变化时都会触发。如果你的机器人管理着大量成员,并且你只关心特定用户的状态,务必在事件处理函数内部添加条件判断(如if after.id == TARGET_MEMBER_ID:)来过滤不相关的事件,以减少不必要的处理负载。
  4. 错误处理: 考虑添加try-except块来处理发送消息时可能出现的异常,例如网络问题或权限不足。
  5. 状态名称: before.status和after.status是discord.Status枚举类型。要获取其字符串表示,可以使用.name属性(如before.status.name),它会返回'online'、'offline'等字符串。
  6. 活动状态: 如果你不仅想检测在线状态,还想检测用户正在进行的游戏或活动,可以比较before.activity和after.activity。after.activity可能是一个discord.Activity对象,你可以从中获取活动的名称、类型等信息。

总结

通过正确配置Intents并利用on_member_update事件,Discord.py机器人可以有效地监听并响应成员的状态变化。这为构建更加智能和互动的机器人功能提供了基础,例如在特定成员上线时发送欢迎消息,或记录成员的在线时长等。遵循本教程的指导和最佳实践,你将能够成功实现这一功能。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

779

2023.08.22

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

183

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

287

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

259

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

125

2025.08.07

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1502

2023.10.24

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

8

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 3.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号