教你拥有一个自己的QQ机器人!0基础超详细保姆级教学!基于NoneBot2 Windows端搭建QQ机器人

news2024/12/29 10:06:41

0.序言

  1. 原文链接:教你本地化部署一个QQ机器人
  2. 本教程主要面向Windows系统用户
  3. 教程从0开始全程详细指导,0基础萌新请放心食用🍕
  4. 如果你遇到了问题,请仔细检查是否哪一步有遗漏。
  5. 如果你确定自己的操作没问题,可以到原文链接下的评论区提问:教你本地化部署一个QQ机器人 ,注意留言时请填写正确的邮箱以确保能收到站长的回复。

1.搭建前的准备工作:

1.1.需要用到的工具

  • 一台24小时开机联网的服务器/计算机
  • 操作系统:Windows10
  • 文本编辑器(强烈推荐使用VSCode)
  • Python3.11.5
  • 一个闲置的QQ账号

1.2.Python安装指南

参考我的这篇文章:Python安装指南

10月2日发布了Python3.12.0版本,站长在10月5日安装机器人框架依赖时会报以下错误:

ERROR: Could not build wheels for yarl, httptools, multidict, which is required to install pyproject.toml-based projects
安装依赖失败! 请手动安装依赖.

尝试了几种方法没有解决,故使用之前成功过的Python3.11.5版本。

Python 3.11.5官方下载链接:Python 3.11.5
国内下载速度可能会有点慢,有条件的可以通过国际网络访问。
站长这里提供Windows64位版本的下载:python-3.11.5-amd64

1.3.VSCode安装指南

VSCode是一款轻量化的IDE,支持市面上绝大多数编程语言,具有良好的扩展性,且具有非常友好的代码补全功能。是CC站长的最爱
下载完成后直接一路确定傻瓜式安装即可//部分自定义配置说明如下:
VSCode

VSCode官网:Visual Studio Code
同样国内下载比较慢,站长这里提供Windows64位1.82.2版本的下载,VSCode支持软件内更新到最新版本:VSCodeUserSetup-x64-1.82.2

2.安装Nonebot框架

2.1.创建文件夹

创建一个文件夹用于存放项目,然后用VSCode打开这个文件夹。
InstallNonebot1

2.2.安装pipx

点击“终端-新建终端”(或直接按住Ctrl+Shift+`)创建一个终端,在终端中输入以下命令:

python -m pip install --user pipx
python -m pipx ensurepath

如果出现以下提示,请调整你的账户环境变量:
InstallNonebot2
调整账户的环境变量参考我的这篇文章:Python安装指南的第三节

安装完成后,关闭当前VSCode窗口,重启VSCode后才会生效。

2.3.安装Nonebot脚手架

创建一个终端,在终端中输入以下命令:

pipx install nb-cli

InstallNonebot3
如果出现无法找到pipx命令的情况(例如出现“Command not found”字样),请确认你在上一步中账户环境变量设置正确,且完全重启VSCode。
如果你确信自己的所有配置完全正确,请尝试重启你的计算机。

3.创建项目

在终端中输入以下命令:

nb create

选择“bootstrap (初学者或用户)”,回车。
Create1

等待资源加载,加载完成后进行如下配置:
(键盘上下键移动光标,空格选中,回车确认)

[?] 项目名称: [为你的项目取个名字吧!] (项目名称建议由英文字母和数字构成,因为部分插件可能不支持包含中文的路径)
[?] 要使用哪些驱动器? FastAPI (FastAPI 驱动器) 
[?] 要使用哪些适配器? OneBot V11 (OneBot V11 协议) 
[?] 立即安装依赖? y
[?] 创建虚拟环境? y

Create2
脚手架会自动创建并引入所需的依赖包。

最后选择安装内置插件echo,这是一个简单的复读回显插件,可以用于测试你的机器人是否正常运行:

[?] 要使用哪些内置插件? echo

请注意,如果你这一步没有安装echo后续将无法进行补装
如果你操作失误没有安装,请删除当前项目文件夹并返回第3节开头。

出现以下提示则项目创建成功
Create3

在终端中输入以下命令进入项目文件夹:

cd [你的项目的名字]

请注意:后续的操作均需要你的终端处于项目文件夹中。
如果你使用的是VSCode,方便起见,你可以直接选择打开项目文件夹作为VSCode工作文件夹:
Create4
这样后续VSCode新建终端就会默认处于项目文件夹中。

4.编辑配置文件

脚手架会在项目文件夹中自动创建一个配置文件.env.prod,但你仍然需要进行一些自定义配置。

打开项目文件夹下的.env.prod文件,编辑内容如下:

DRIVER=~fastapi  # 脚手架自动生成的配置

HOST=127.0.0.1  # 配置 NoneBot 监听的 IP / 主机名
PORT=23333  # 配置 NoneBot 监听的端口

其中HOST必须设为127.0.0.1(即localhost)
PORT可以选择你喜欢的数字,范围在0-65535之间。不设置默认为8080,但尽量在15000-50000之间选择,避免和已有的端口发生冲突。

此外,你可以选择设置命令起始字符COMMAND_START和命令分割字符COMMAND_SEP,你可以在有需要使用这些设置的时候再行配置。
设置命令起始字符后,机器人只响应以起始字符开头的命令。
设置命令分割字符后,你可以用一个语句包含多个命令,机器人会先按分割字符将命令分开,再按顺序处理。

COMMAND_START=["/"]  # 配置命令起始字符(可选)
COMMAND_SEP=["."]  # 配置命令分割字符(可选)

5.安装插件

5.1.管理插件的方法

本节旨在让读者了解操作管理插件的流程,选择自己喜欢的管理插件的方式。
你也可以选择先跳过本节,在后面的教程中会默认提供方法一的命令。

Nonebot提供了三种管理插件的方法,请确保你的终端当前处于项目文件夹中。
其中使用pip安装(方法三)需要手动激活Python虚拟环境,方法一、二管理插件时会自动使用虚拟环境。

5.1.1.方法一:命令行管理

在终端输入以下命令:

nb plugin install <插件名称>  # 安装插件
nb plugin uninstall <插件名称>  # 卸载插件
nb plugin update <插件名称>  # 升级插件
nb plugin list  # 列出商店所有插件
nb plugin search [关键词]  # 搜索商店插件

5.1.2.方法二:交互式管理

在终端输入以下命令:

nb plugin

将进入控制台交互模式,键盘上下键移动光标,空格选中,回车确认。
Plugin1
按照提示输入插件名称即可。

5.1.3.方法三:使用pip安装

如果你在第3节中正确创建了项目,那么你的项目文件夹中会有一个.venv文件夹,这是项目的Python虚拟环境文件夹。

值得一提的是,虚拟环境是Python提供的一个非常实用的功能,它可以将项目环境和全局环境隔离。
你可以在虚拟环境中安装和管理项目特定的Python库和依赖项,而不会与全局Python环境相互影响。

在终端输入以下命令以激活虚拟环境:

.\.venv\Scripts\activate

如果遇到“禁止运行脚本”的报错,可以参考我的这篇文章来解决:Windows系统无法激活Python虚拟环境的解决方案
如果命令行开头出现一个括号,内容为你的项目名称,则代表Python虚拟环境已经成功激活。

接下来你可以使用pip命令来管理你的插件:

pip install <插件名称>  # 安装插件
pip uninstall <插件名称>  # 卸载插件
pip install --upgrade <插件名称>  # 升级插件
pip list  # 列出当前已经安装的插件(包含Nonebot依赖包)

pip相比前两种方法,缺少了列出和搜索商店插件的功能,多了可以查询当前已经安装了的插件的功能。
在忘记已经安装的插件或插件名情况下查询比较方便(当然你也可以自己在.\.venv\Lib\site-packages里查看)。

5.2.安装go-cqhttp

go-cqhttp框架提供了接收QQ事件与调用QQ的API的能力,是QQ机器人的核心组件。
NoneBot插件商店中提供了这个框架的插件,插件名称为:nonebot-plugin-gocqhttp
在终端中输入以下命令安装插件:

nb plugin install nonebot-plugin-gocqhttp

安装完成后,在终端中输入以下命令运行机器人:

nb run

出现以下提示则安装和运行成功:
gocq1
按住Ctrl单击链接进入go-cqhttp的WebUI界面
gocq2

6.登录QQ机器人与检查

6.1.登录QQ机器人

点击左上角“添加账号”,输入要部署的QQ账号,密码留空,设备类型选择“Android Watch”:
(注:也可以选择账号密码登录,但可能出现账号被风控无法登录的情况,手表协议登录相对比较稳定。)
QQLogin1
添加完成后点击启动,待加载出二维码后点击“显示登录二维码”。
用你的手机登录要部署的QQ账号,扫描二维码登录。
QQLogin2
登陆完成后会有消息提示如下:
QQLogin3

6.2.检查QQ机器人是否正常运行

登录你自己的QQ账号,添加机器人为QQ好友,然后按以下格式发送给机器人消息:

\echo [自定义消息]

请注意,不论你有没有配置命令起始字符,在这里echo的开头必须包含""字符
如果机器人回复了和自定义消息相同的内容,那么恭喜你,你已经成功地完成了QQ机器人的部署。
示例:
image

7.为你的QQ机器人赋能

完成了QQ机器人部署后,你就可以为你的机器人添加插件以实现各种各样的功能。插件的管理方式见5.1节。
你可以在官方插件商店找到你需要的插件,根据插件开发者提供的的文档进行安装与配置:插件商店。
如果你有足够的能力和精力,可以学习NoneBot文档,编写开发自己的插件:NoneBot文档。

8.注意事项

  1. 机器人的运行进程由终端调起,在你运行机器人的过程中,请务必保证你原来的终端窗口一直保持开启状态。如果你使用的是VSCode之类的IDE,请不要关闭你终端所在的窗口。
  2. 机器人以你的计算机作为服务器端,BOT使用期间请务必保证你的服务器/计算机处于开机联网状态。
  3. Windows系统时常会进行自动更新,必要时可以关闭自动更新。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1063655.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

苹果macbook电脑磁盘满了怎么清理内存

如果你是苹果macbook用户&#xff0c;可能会面临一个常见但又令人头疼的问题——磁盘空间不足。这不仅影响了你的电脑性能&#xff0c;还可能导致新的软件无法安装&#xff0c;甚至影响到文件的保存。好消息是&#xff0c;有多种方法可以有效地解决这个问题。下面就一起来看看吧…

【100个 Unity实用技能】☀️ | UGUI Text中加入超链接文本,可直接点击跳转

Unity 小科普 老规矩&#xff0c;先介绍一下 Unity 的科普小知识&#xff1a; Unity是 实时3D互动内容创作和运营平台 。包括游戏开发、美术、建筑、汽车设计、影视在内的所有创作者&#xff0c;借助 Unity 将创意变成现实。Unity 平台提供一整套完善的软件解决方案&#xff…

unity脚本_Input鼠标键盘 c#

获取鼠标坐标 检测鼠标输入 如果在运行游戏场景中点击一下鼠标左键 检测鼠标抬起 选中即可 检测键盘按下 当前屏幕分辨率 注意&#xff1a;获取的是显示器的分辨率 获取设备屏幕宽高 屏幕休眠模式 窗口/全屏模式 移动设备屏幕转向

【C语言】字符函数和字符串函数(1)

#国庆发生的那些事儿# 大家好&#xff0c;我是苏貝&#xff0c;本篇博客带大家了解字符函数和字符串函数&#xff0c;如果你觉得我写的还不错的话&#xff0c;可以给我一个赞&#x1f44d;吗&#xff0c;感谢❤️ 目录 1.本章重点2. strlen2.1函数介绍2.2 模拟实现 3. strcpy3…

第八章 排序 六、简单选择排序

目录 一、算法思想 二、例子 1、我们有以下序列要排序 2、首先从左往右扫描&#xff0c;在其中找到最小的一个数&#xff0c;让它与第一个数互换位置 3、此次扫描完成后&#xff0c;我们取新的子序列&#xff0c;并再次从左往右扫描&#xff0c;在其中找到最小的一个数&…

makeMakefile

一、 什么是make&Makefile &#xff1f; ①make 是一条命令,makefile是一个文件,配合使用,通过依赖关系和依赖方法达到我们形成可执行程序的目的 ②makefile好处就是可以进行 自动化编译 ” &#xff0c;极大的提高软件开发的效率,一旦写好&#xff0c;只需要一个 make 命令…

推荐一款在线的JDK17中文文档

spring6.0及springboot3.0最低版本要求都是java17&#xff0c;换上java17是迟早的事&#xff0c;所以虽然我现在做的是java8&#xff0c;但是后面我想从java8直接飞升到java17&#xff0c;先做个准备&#xff0c;找到一个JDK17的中文文档&#xff0c;是在线的&#xff0c;地址&…

数据结构刷题训练——二叉树篇(一)

&#x1f4d9;作者简介&#xff1a; 清水加冰&#xff0c;目前大二在读&#xff0c;正在学习C/C、Python、操作系统、数据库等。 &#x1f4d8;相关专栏&#xff1a;C语言初阶、C语言进阶、C语言刷题训练营、数据结构刷题训练营、有感兴趣的可以看一看。 欢迎点赞 &#x1f44d…

学习记忆——方法篇——整除特点

理解记忆法 对于数的整除特征大家都比较熟悉&#xff1a;比如4看后两位&#xff08;因为100是4的倍数&#xff09;&#xff0c;8看后三位&#xff08;因为1000是8的倍数&#xff09;&#xff0c;5末尾是0或5&#xff0c;3与9看各位数字和等等&#xff0c;今天重点研究一下3,9,…

创新家庭办公室:打造完美工作空间的秘诀

一个精心策划的家庭办公室有很多好处&#xff0c;何不把临时工作区升级改造为你的专属工作区呢&#xff0c;还能为这些至关重要的区域注入新的活力。 创造多用途的起居室&#xff1a;我们大多数人都不曾拥有一个可以完全根据工作需求设计的独立家庭办公室——所以有时候要找到…

目标检测算法改进系列之Backbone替换为RIFormer

RIFormer简介 Token Mixer是ViT骨干非常重要的组成成分&#xff0c;它用于对不同空域位置信息进行自适应聚合&#xff0c;但常规的自注意力往往存在高计算复杂度与高延迟问题。而直接移除Token Mixer又会导致不完备的结构先验&#xff0c;进而导致严重的性能下降。 原文地址&…

Pytorch之shuffleNet图像分类

&#x1f482; 个人主页:风间琉璃&#x1f91f; 版权: 本文由【风间琉璃】原创、在CSDN首发、需要转载请联系博主&#x1f4ac; 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦 前言 ShuffleNet是Face&#xff08;旷视&#xff09;在2017年发布的一个高效率…

【傅里叶梅林图像配准】用于图像配准的傅里叶梅林相位相关性的实现(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

Python之元组

Python之元组 元组tuple 一个有序的元素组成的集合使用小括号 ( ) 表示元组是不可变对象 tuple(), (), type(()) # 空元组 ((), (), tuple)(1,), (1) # 元组中只有1必须加逗号&#xff0c;否则就是1了 # ((1,), 1)x 1, 2 # 以逗号分隔的内容会形成元组&#xff0c;封装元组x…

壁炉装饰:突破传统的创新趋势

壁炉&#xff0c;一直以来都是家庭温馨的象征&#xff0c;但它也是家居装饰中一个充满潜力的元素。如今&#xff0c;随着设计趋势的不断演变&#xff0c;壁炉装饰已经迈入了一个全新的时代&#xff0c;融合了美学、功能和可持续性&#xff0c;为家庭创造了更多可能性。 壁炉装饰…

强化学习环境 - robogym - 学习 - 3

强化学习环境 - robogym - 学习 - 3 文章目录 强化学习环境 - robogym - 学习 - 3项目地址为什么选择 robogymObservation - 观测信息Action - 动作信息Initialization - 初始状态设置 项目地址 https://github.com/openai/robogym 为什么选择 robogym 自己的项目需要做一些机…

04.数据解析之css选择器

1、常见数据类型 结构化的数据是指可以使用关系型数据库表示和存储&#xff0c;表现为二维形式的数据。一般特点是&#xff1a;数据以行为单位&#xff0c;一行数据表示一个实体的信息&#xff0c;每一行数据的属性是相同的。 1、1 结构化数据 ​ 结构化的数据是指可以使用关…

策略模式与模板方法结合案例

一、背景 上周在迁移项目MQ工程的时候&#xff0c;重新Review代码&#xff0c;发现有一段代码综合使用了策略模式和模板方法&#xff0c;下面讲解一下具体场景应用的思路。 二、模板方法 策略模式前段时间有一个关于库存具体案例&#xff0c;详见 库存管理与策略模式。 模板…

智能银行卡明细筛选与统计,轻松掌握账户总花销!

作为现代生活的重要组成部分&#xff0c;银行卡成为了我们日常消费和收入的主要途径。但是&#xff0c;当我们需要了解自己的银行卡账户的总花销时&#xff0c;繁琐的明细筛选和统计工作常常让人头疼。现在&#xff0c;让我们向您推荐一款智能银行卡明细筛选与统计工具&#xf…

基于SpringBoot的学生选课系统

基于SpringBoot的学生选课系统的设计与实现&#xff0c;前后端分离 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringBootMyBatisVue工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 前台主页 登录界面 管理员界面 教师界面 学生界面 摘要 学生选课系统…