跑团骰娘机器人欧若可, 支持 QQ频道 及 Nonebot2 部署.
Project description
DicerGirl
介绍
跑团骰娘机器人欧若可, 支持 QQ频道 及 Nonebot2 部署.
软件架构
任何支持 Python3 环境搭建的平台, 建议使用 Python3.10 及以上的 Python 版本, DicerGirl 不支持 Python2.
版本特性
同时支持基于qq-botpy
的 QQ频道机器人 以及 Nonebot2 Onebot v11. 这使得该库可以在不进行迁移修改的情况下完全兼容腾讯官方支持的 QQ频道机器人 以及功能强大的 Nonebot2.
QQ频道 以及 Nonebot2 的区别
QQ 频道机器人仅支持在 QQ频道 中运行, 你需要创建一个 QQ频道, 这个方案是安全的且被腾讯官方推荐的, 但是它会受到诸多限制, 譬如禁止机器人发送未经审核的链接、禁止机器人发送未经审核的图片等, 同时, QQ频道机器人还存在单日的消息推送上限. 你在使用 QQ 频道机器人模式之前, 需要先前往 QQ 开放平台 注册账号并创建机器人.
基于 Nonebot2、Onebot v11 以及 Go-CQHTTP 实现的 QQ 机器人则不存在任何限制, 你甚至可以像使用 QQ 软件一样调用所有你在软件中能够发送的消息类型的 API. 然而, 这并不是一个安全的方案, 因为腾讯对于采用非官方 API 的 QQ 机器人似乎是深恶痛绝的, 所以你可能会常常遭到腾讯的风控甚至封号, 即便设置了 QSign 的老账号也有可能遭到封号, 不过当你被系统封号一次并完成实名认证之后, 腾讯一般不会再进行封号处理.
安装教程
1. 安装 Python 环境
Windows 系统
Python3.11.4 官方下载地址 , 由于 python.org 在国内的访问速度问题, 该下载地址可能会耗时较长.
Python3.11.4 NPM镜像源 国内下载地址.
注意,在安装过程中,请注意选择将 Python 加入环境变量(Path)中.
Ubuntu/Debian/Kali Linux
apt install python3 python3-pip -y
CentOS
yum install python3 python3-devel python3-pip -y
打开系统终端(Windows 中打开 cmd.exe 或 Powershell), 输入python -V
和pip -V
, 显示版本信息即代表安装成功.
2. 安装依赖库
首先升级 pip 到最新版:
python -m pip install --upgrade pip
pip install wheel setuptools --upgrade
如果你使用 QQ频道模式, 你需要安装 Dicer 所需要的依赖库, 在终端中键入:
pip install watchdog qq-botpy loguru
如果你使用 Nonebot2 模式, 你需要安装 Nonebot2:
pip install nb-cli
如果你在更新pip
之后, 你的设备安装nb-cli
依旧出现错误, 在安装 Dicer Girl 的时候, 你可以采用 Python Nonebot2 原生的bot.py
模式, 来取代nb run
指令.
如果你同时部署这两者, 你可以直接采取:
pip install -r requirements.txt
这会安装 Dicer 所需要的所有依赖库.
对于 Nonebot2 与 Go-CQHTTP 的配置和使用, 这里不进行过多赘述.
3. 安装 DicerGirl
使用以下指令安装 DicerGirl:
pip install dicergirl
频道模式
如果你使用 QQ频道模式, 你需要穿件一个.py
文件并写入以下内容
from dicergirl.utils.utils import init, set_config
from dicergirl.utils.settings import set_package
from dicergirl.run import main
init() # 初始化 Dicer Girl
set_package("qqguild") # 声明使用`qqguild`模式
set_config("1020*****", "RiFuHMFembccObW*****************") # 分别填入你的 BotAppID 和机器人令牌
if __name__ == "__main__":
main()
请注意在执行指令之前依照 QQ 开放平台配置自己的机器人,并开启并创建 QQ频道.
Nonebot2 模式
- 安装 Dicer Girl
直接安装
如果你使用 Nonebot2 作为 Dicer 的引擎, 你应当先注意你是否需要激活虚拟环境, 并执行:
pip install dicergirl
使用nb-cli
创建的 Nonebot2 项目是推荐使用虚拟环境的, 不过你在执行nb create
之后, 是否创建虚拟环境这一选项是可选的.
如果你不知道如何激活虚拟环境, 且你使用了 Nonebot2 默认的venv
而不是conda
, 那么你应该打开你的 Nonebot2 项目, 进入.venv
目录中, 找到pip
(Windows 中是 pip.exe
), 然后进入该可执行文件的文件夹, 再执行以上命令.
如果你使用conda
作为虚拟环境, 你应当执行:
conda activate [venv]
其中[venv]
应该被替换为你设定的 conda 虚拟环境名称.
源文件安装
或者你也可以将克隆的仓库拷贝到: 你的Nonebot2项目目录/src
中, 并在 pyproject.toml 中的plugin_dirs
参数中加入['src']
, 这与直接安装的结果是等同的, 但是这不利于你收到 DicerGirl 的最新更新.
- 启动项目
使用nb-cli
启动
之后, 在终端切入你的 Nonebot2 项目目录并执行:
nb run --reload
其中, --reload
意味着你启用了 Nonebot2 自带的热重载模式, 它使得你可以在你修改某些 Nonebot2、Dicer Girl 或者你自行加入的第三方依赖库之后, 在不手动终止程序的情况下让 Nonebot2 自行判断是否需要重载项目.
使用bot.py
原生启动
如果你无法成功通过pip
安装nb-cli
, 你使用安装nonebot2
来替代:
pip install nonebot2 nonebot-adapter-onebot nonebot2[fastapi] nonebot2[httpx] nonebot2[websockets]
安装成功后, 新建一个文件夹, 并创建bot.py
、pyproject.toml
、.env.prod
三个文件, 以及一个空文件README.md
.
分别写入以下内容:
bot.py
#!/bin/python
# 文件: bot.py
from nonebot.adapters.onebot.v11 import Adapter as ONEBOT_V11Adapter
nonebot.init()
driver = nonebot.get_driver()
driver.register_adapter(ONEBOT_V11Adapter)
nonebot.load_builtin_plugins('echo')
nonebot.load_from_toml("pyproject.toml")
if __name__ == "__main__":
nonebot.run()
pyproject.toml
# 文件: pyproject.toml
[project]
name = "oracle-dicer"
version = "0.1.0"
description = "oracle-dicer"
readme = "README.md"
requires-python = ">=3.8, <4.0"
[tool.nonebot]
adapters = [
{ name = "OneBot V11", module_name = "nonebot.adapters.onebot.v11" }
]
plugins = ['dicergirl']
plugin_dirs = ['src']
builtin_plugins = ["echo"]
.env.prod
DRIVER=~fastapi+~httpx+~websockets
完成后, 打开终端, 执行:
python3 bot.py
如果你是 Windows 系统, 请使用python
来替代python3
:
python bot.py
使用
你可以在部署完成后, 在相应的 QQ 群或者 QQ 频道发送消息.help
来查看使用方法.
目前已兼容 COC 跑团与 SCP 跑团的大部分指令.
欧若可骰娘 Version 3.0.5
此骰娘基于腾讯QQ机器人(botpy)搭建, 由欧若可(Oracle)提供部分算法支持.
最终版本由未知访客团队(Unknow Visitor, 原左旋联盟)完成.
感谢 灵冬-老孙 提供相关技术支持.
.help 帮助信息
.su 进行超级管理员鉴权
.coc 进行车卡, 完成 COC 角色作成
.scp 进行车卡, 完成 SCP 角色作成
.mode 切换当前跑团模式
.r 投掷指令 例如:
.r 10 100 (10D100)
.r 10d100 (10D100)
d 制定骰子面数
a 检定
.ra [str: 数据名] 例如:
.ra 幸运 (默认为幸运值D100)
.ra 幸运 80 (幸运值D80)
.ra 力量 90 (力量值D90)
h 暗骰 - 无效算法
# 多轮检定
bp 奖励骰&惩罚骰 - 无效算法
+/- 附加计算 - 无效算法
.sra 基金会特工标准检定
.dam 调查员或特工承伤检定
.at 调查员或特工伤害检定
.sc 疯狂检定
.st 射击命中判定
.ti 临时疯狂症状
.li 总结疯狂症状
.en 技能成长 - 无效算法
.set 角色卡设定
.set [str: 数据名] [int: 数据]
.show 角色卡查询
.sa COC快速检定
.del 删除数据
.del c 删除临时数据
.del card 删除存储数据
输入`.help [指令名]`获取该指令的详细信息
注: 以上的 "aDb" 格式(例如10D100)的内容, 表示模拟投掷100面骰子, 投掷10次, 结果小于检定值则检定通过.
欧若可骰娘 版本 3.0.4, 未知访客版权所有.
Copyright © 2011-2023 Unknown Visitor. All Rights Reserved.
声明
此项目由 Apache-2.0 协议开源, 使用代码时, 请注意遵照开源协议.
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
Hashes for dicergirl-3.1.5-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 78cbed1f1bad411b435d141c965624b789c87d39182893be9a350c9367155cc6 |
|
MD5 | 10b73e2598342d562c4160d496f873ff |
|
BLAKE2b-256 | bc622d10469cceceadceda042fdacad04444b5fa75049b43b0a1060328cbb717 |