播报群友 Steam 游戏状态
Project description
📖 介绍
在群内播报群友的 Steam 游戏状态
💿 安装
使用 nb-cli 安装
在 nonebot2 项目的根目录下打开命令行, 输入以下指令即可安装nb plugin install nonebot-plugin-steam-game-status
使用包管理器安装
在 nonebot2 项目的插件目录下, 打开命令行, 根据你使用的包管理器, 输入相应的安装命令pip
pip install nonebot-plugin-steam-game-status
pdm
pdm add nonebot-plugin-steam-game-status
poetry
poetry add nonebot-plugin-steam-game-status
conda
conda install nonebot-plugin-steam-game-status
uv
uv add nonebot-plugin-steam-game-status
更新
pip install nonebot-plugin-steam-game-status --upgrade
打开 nonebot2 项目根目录下的 pyproject.toml 文件, 在 [tool.nonebot] 部分追加写入
plugins = [
"nonebot_plugin_steam_game_status"
]
⚙️ 配置
在 nonebot2 项目的.env文件中添加下表中的必填配置
| 配置项 | 必填 | 默认值 | 类型 | 说明 |
|---|---|---|---|---|
| steam_web_key | 是 | 无 | str 或 list | Steam Api Key |
| steam_isthereanydeal_key | 否 | 无 | str 或 list | isthereanydeal Api Key 查询史低 |
| steam_command_priority | 否 | 5 | int | 事件处理函数优先级 |
| steam_interval | 否 | 1 | int | steam查询间隔,单位分钟 |
| steam_tail_tone | 否 | "" | str | bot尾音口癖 |
| steam_proxy | 否 | None | str | 代理 |
| steam_api_proxy | 否 | None | str | Steam API 反代域名 |
| steam_store_proxy | 否 | None | str | Steam Store 反代域名 |
| steam_link_enabled | 否 | true | bool | 链接识别全局开关 |
| steam_area_game | 否 | false | bool/list | 识别其它区游戏 |
| steam_link_r18_game | 否 | false | bool/list | 识别r18游戏 |
| steam_tail_tone | 否 | "" | str | bot尾音 |
| steam_subscribe_time | 否 | ["08:00"] | str/List[str] | 喜加一订阅检索推送时间 |
steam_tail_tone 示例
# .env.xxx
steam_tail_tone=" 喵"
steam_subscribe_time 示例
# .env.xxx
steam_subscribe_time="20:30"
# 或者多个时间
steam_subscribe_time=["08:00","20:30"]
steam_proxy 示例
# .env.xxx
steam_proxy="http://ip:port"
steam_api_proxy 和 steam_store_proxy 反代域名配置示例
# .env.xxx
# 用于替代 api.steampowered.com
steam_api_proxy="api.proxy.example.com"
# 用于替代 store.steampowered.com
steam_store_proxy="store.proxy.example.com"
单个 steam key 配置示例 (steam_isthereanydeal_key 同理)
# .env.xxx
steam_web_key=123456789QWERTYUII123456789
# or 引号包裹
steam_web_key="123456789QWERTYUII123456789"
# 若字符串形式key绑定失败,请改写为以下多key配置
多个 steam key 配置示例 (steam_isthereanydeal_key 同理)
# .env.xxx
# 注意最后一行key后面不能有逗号
steam_web_key='[
"123456789QWERTYUII123456789",
"123456789",
"987654321"
]'
# or 无引号包裹
steam_web_key=["123456789QWERTYUII123456789","123456789","987654321"]
steam_area_game 识别其它区游戏
# .env.xxx
# 使用布尔值开启或关闭
steam_area_game=false
# 使用群聊/私聊白名单列表
steam_area_game='["群号1","群号2"]'
# or
steam_area_game='
[
"群号1",
"群号2"
]'
steam_link_r18_game 识别r18游戏
# .env.xxx
# 使用布尔值开启或关闭
steam_link_r18_game=false
# 使用群聊/私聊白名单列表
steam_link_r18_game='["群号1","群号2"]'
# or
steam_link_r18_game='
[
"群号1",
"群号2"
]'
插件依赖于 客户端驱动器
请确保安装了客户端驱动器,如
# 使用官方命令
nb driver install aiohttp
# 或
pip install nonebot2[aiohttp]
# 或
pip install nonebot2[httpx]
并配置DRIVER=~aiohttp等
史低查询依赖于 IsThereAnyDeal
- 首先打开并登录 IsThereAnyDeal,可使用steam登录
- 访问 app页 并注册app
- 注册完成后,右侧会出现
API Keys,点击key即可复制 .env.xxx配置文件种添加steam_isthereanydeal_key
🎉 使用
获取SteamID64
Steam 桌面网站或桌面客户端:点开右上角昵称下拉菜单,点击账户明细,即可看到 Steam ID
Steam 应用:点击右上角头像,点击账户明细,即可看到 Steam ID
获取Steam好友代码
Steam 桌面网站或桌面客户端:点开导航栏 好友 选项卡,点击添加好友,即可看到 Steam 好友代码
Steam 应用:点击右上角头像,点击好友,点击添加好友,即可看到 Steam 好友代码
指令表
| 指令 | 需要@ | 范围 | 权限 | 说明 |
|---|---|---|---|---|
| steam绑定/steam添加/steam.add | 否 | 群聊 | 群员 | 后加个人SteamID64或好友代码 |
| steam解绑/steam删除/steam.del | 否 | 群聊 | 群员 | 后加个人SteamID64 |
| steam列表/steam绑定列表 | 否 | 群聊 | 群员 | 展示群内播报列表 |
| steam屏蔽 | 否 | 群聊 | 群员 | 后加完整游戏名称 |
| steam恢复 | 否 | 群聊 | 群员 | 后加完整游戏名称 |
| steam排除列表 | 否 | 群聊 | 群员 | 展示屏蔽的游戏列表 |
| steam播报开启/steam播报打开 | 否 | 群聊 | 群员 | 开启本群播报 |
| steam播报关闭/steam播报停止 | 否 | 群聊 | 群员 | 关闭本群播报 |
| steam喜加一 | 否 | 群聊 | 群员 | 主动获取喜加一资讯 |
| steam喜加一订阅 | 否 | 群聊 | 群员 | 开启本群喜加一推送 |
| steam喜加一退订 | 否 | 群聊 | 群员 | 关闭本群喜加一推送 |
| steam折扣订阅 | 否 | 群聊 | 群员 | 后加游戏id,开启本群折扣推送 |
| steam折扣退订 | 否 | 群聊 | 群员 | 后加游戏id,开启本群折扣推送 |
| steam墙 | 否 | 群聊 | 群员 | 后加用户id,展示steam游玩时长拼图 |
| steam失联群列表 | 否 | 群聊/私聊 | 超管 | 展示与bot失联群聊列表 |
| steam失联群清理 | 否 | 群聊/私聊 | 超管 | 从存储中删除失联群聊相关绑定订阅 |
| 任意steam商店链接 | 否 | 群聊/私聊 | 群员/好友 | 获取游戏信息 |
默认屏蔽游戏/工具名
["Wallpaper Engine:壁纸引擎","虚拟桌宠模拟器","OVR Toolkit","OVR Advanced Settings","OBS Studio","VTube Studio","Live2DViewerEX","Blender","LIV"]
目前建议手动添加
Dead Lock,待发售完善后再移除,否则容易刷屏
创意来源
群友的 koishi bot 的该效果插件
注意事项
- 不支持播报非 Steam 游戏
- 不支持播报 Steam 隐身状态下进行的游戏
- 在屏蔽游戏间切换的非屏蔽游戏也不会播报
- 屏蔽游戏列表以群区分管理
- 0.2版本已知问题:多个同适配器bot(如多个OneBot)目前还存在选择错误而推送群消息失败的问题,后续修复
更新记录
2025.11.30 0.3.0
- 添加steam游戏时长拼图获取
- 添加bot失联群管理
- 添加游戏折扣订阅
- 添加多时间订阅能力
- 添加steam域名反代
- 修复部分问题
2025.09.18 0.2.6
- 兼容回 pydantic v1 版本
- 去除工具插件依赖,添加回 OneBot 依赖
- 修复新装插件处理文件bug
2025.09.15 0.2.3
- 添加喜加一及其订阅功能
- 增加游戏史低显示
- 修复屏蔽游戏指令对带空格的游戏名不生效的问题
- 修复OneBot适配器推送不在群聊的消息问题(多bot问题)
2025.09.04 0.2.1
- 修复部分预发布游戏没有标签导致识别失败
- 修复跨平台多适配器下消息推送失败
- 0.2版本已知问题:多个同适配器bot(如多个OneBot)目前还存在选择错误而推送群消息失败的问题,后续修复
2025.08.21 0.2.0
- 改用alconna插件实现,支持跨平台适配器
- 为链接识别增加白名单配置
- 使用驱动器实现,解决代理参数和依赖问题
- 小幅度优化数据存储,更新后会自动进行迁移
2025.07.27
- 修复onebot适配器故障导致无法推送消息
- 优化游戏链接识别显示效果
- 修复
httpx 0.28.1版本代理参数
2024.10.21
- 修复用户id数据异常
2024.09.16
- 优化
steam链接识别,降低失败可能性 - 增加
steam列表展示当前游戏 - 优化重启后不再播报仍在继续的游戏
2024.06.30
- 优化游戏中文名获取
2024.06.27
- 修复添加新群时数据未保存的bug
2024.06.26
- 优化播报后数据同步优先级
- 添加链接识别功能
- 优化日志等级
2024.06.23
- 添加
屏蔽游戏相关功能 - 修复steam列表问题
2024.04.28
- steam列表 合并消息优化
2024.02.29
- 新增游戏中文名播报,感谢 6DDUU6 的 PR
- 顺应 Nonebot 规范,缓存文件迁移至用户目录下,详见 plugin-localstore
- 调整数据结构,节省 key
- 变更原缓存记录从 每次读取文件 更改为 持续在内存中
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nonebot_plugin_steam_game_status-0.3.5.tar.gz.
File metadata
- Download URL: nonebot_plugin_steam_game_status-0.3.5.tar.gz
- Upload date:
- Size: 39.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b3fb50b6a6a1889ebaedef0b12092a45144986289b9842cbaf5c86a5af79a6b1
|
|
| MD5 |
71b2685da84c9154aedaedba34c84364
|
|
| BLAKE2b-256 |
9fd2735f10732276435957ec9e546dd5e728aaef7ca3aac749a8144acd2f4fba
|
File details
Details for the file nonebot_plugin_steam_game_status-0.3.5-py3-none-any.whl.
File metadata
- Download URL: nonebot_plugin_steam_game_status-0.3.5-py3-none-any.whl
- Upload date:
- Size: 39.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6db8f41b723f5ba4cb06d99ea259f1a596b19a5eef80a735830e72de7bd8d5d1
|
|
| MD5 |
6d01d13df34a0d7edbad1535c69a42ec
|
|
| BLAKE2b-256 |
2ae290eb88ab4f34d628d97b713421063e4aea4c98d4824fe19041c56dd331c5
|