nonebot2 插件编写指南(初级)(2.0.0a16之前)

2023-10-28 05:59

本文主要是介绍nonebot2 插件编写指南(初级)(2.0.0a16之前),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

nonebot2 插件编写指南(初级)

这篇文章将从零教你白手起一个插件(
并辅以现写一个获取命运 2 每日日报的插件
(感谢天阙提供的日报 api 接口)
本文另发于个人博客:这里


阅读这篇文章,你至少需要以下技能:

  • 部分 python 知识
  • nb2 的部分使用方式
  • 使用百度排除故障的能力

官方提供的教程:创建插件

1.如何创建一个插件?

因日报插件体量非常小,因选择单文件插件创建方式
在你的 nb2 目录找到你的 bot,在 bot 文件夹下找到 plugins 文件夹
这里存放着用户自定义的插件,而官方插件存放在 python 的包目录下

若找不到 plugins 文件夹,请使用:

nb plugin new

在 plugins 文件夹下创建文件today.py
插件文件就创建好了

2.需要用到的包

首先我们要引入 nonebot 的必要包:

#事件响应器函数
from nonebot import on_command, on_startswith
#rule事件响应规则(需要@bot才能响应事件)
from nonebot.rule import to_me
#bot使用的对象和字典
from nonebot.typing import T_State
from nonebot.adapters import Bot, Event

这些包也是一会要用到的:

#massage是使用cq码的必要函数
from nonebot.adapters.cqhttp.message import Message
#使用无头浏览器访问api地址
import urllib3
#处理api返回的json数据
import json

3.事件响应器

要使你的 bot 能识别 qq 消息关键词,并对消息做出响应,你需要注册一个事件响应器
响应器格式为:

事件函数名=响应器函数("事件响应器名",[aliases={'响应关键词1','响应关键词2', }],priority=响应优先级,[rule=响应器规则])

日报的事件响应器可以这样写:

today = on_command("today", aliases={'调试/日报', }, priority=5)

使用调试/日报可以激活此函数响应,优先级为 5

handle

handle()是处理事件的主体部分,是事件处理的起点(不包括预处理)
在函数前加上这段来进行说明这是一个handle

@today.handle()

然后创建一个异步函数:

async def handle_first_receive(bot: Bot, event: Event, state: T_State):

接下来的内容可以在脚本之外先提前测试
访问 api 并读取返回的 json 值,并转换成可读格式:

url = 'http://www.tianque.top/d2api/today/'r = urllib3.PoolManager().request('GET', url)
hjson = json.loads(r.data.decode())

例如,今天为 2021.6.6,返回值为:

{"today": "2021-06-06","img_name": "2021-06-06.png","img_hash_md5": "47198c45cc64068859e2b8dc3ef3c110","img_url": "https://cdn.max-c.com/heybox/dailynews/img/d227cae814dacb6434ae0617bc3131a5.png","width": 1063,"height": 4770
}

提取图片地址:

img_url = hjson["img_url"]

这时,图片的网址就提前并存入变量了,而发送图片需要一个特殊的格式—cq 码

cq 码

CQ 码,是指在酷 Q Pro / Air 的消息中,以 [CQ:开头、 ] 结尾的,可以实现特殊功能的代码。
酷 Q 虽已不再使用,但 cq 码却保留了下来

发送图片的 cq 格式为:

[CQ:image,file=%文件名%]

其中%文件名%可为网址或本地协议(例如 go-cqhttp)本地文件夹下的 data/image 文件夹内文件
构建 cq 码:

cq = "[CQ:image,file=" + img_url + ",id=40000]"

id=40000 表示为默认特效

本地运行

根据以上语句,测试 python 完整代码为:

import urllib3
import jsonurl = 'http://www.tianque.top/d2api/today/'r = urllib3.PoolManager().request('GET', url)
hjson = json.loads(r.data.decode())
img_url = hjson["img_url"]
cq = "[CQ:image,file=" + img_url + ",id=40000]"
print(cq)

如果调试无问题,那么结果应为:

[CQ:image,file=https://cdn.max-c.com/heybox/dailynews/img/d227cae814dacb6434ae0617bc3131a5.png,id=40000]

使用 send 来发送消息:

await today.send(Message(cq))

cq 码需要使用 Massage()来处理才能正常识别为图片并发送

完整代码

from nonebot import on_command, on_startswith
from nonebot.typing import T_State
from nonebot.adapters import Bot, Event
from nonebot.adapters.cqhttp.message import Messageimport urllib3
import jsontoday = on_command("today", aliases={'调试/日报', }, priority=5)@today.handle()
async def handle_first_receive(bot: Bot, event: Event, state: T_State):url = 'http://www.tianque.top/d2api/today/'r = urllib3.PoolManager().request('GET', url)hjson = json.loads(r.data.decode())img_url = hjson["img_url"]cq = "[CQ:image,file=" + img_url + ",id=40000]"await today.send(Message(cq))

优化

日报更新与棒鸡服务器和天阙的服务器状态挂钩,若无法更新则会无法读取图片地址,bot 将无任何返回值,无反馈的错误是一件很糟糕的事
我们使用try-except来做一个简单的异常嵌套:

from nonebot import on_command, on_startswith
from nonebot.typing import T_State
from nonebot.adapters import Bot, Event
from nonebot.adapters.cqhttp.message import Messageimport urllib3
import jsontoday = on_command("today", aliases={'调试/日报', }, priority=5)@today.handle()
async def handle_first_receive(bot: Bot, event: Event, state: T_State):try:try:url = 'http://www.tianque.top/d2api/today/'r = urllib3.PoolManager().request('GET', url)hjson = json.loads(r.data.decode())img_url = hjson["img_url"]#print(img_url)cq = "[CQ:image,file=" + img_url + ",id=40000]"await today.send(Message('json:\n'+str(hjson)+'\nimg_url:\n'+img_url+'\n'+cq))except:url = 'http://www.tianque.top/d2api/today/'r = urllib3.PoolManager().request('GET', url)hjson = json.loads(r.data.decode())error_url = hjson["error"]await today.send("获取日报失败\n"+"error:\n"+error_url)except :await today.send("获取日报失败:\n服务器错误")

虽然比较简陋,但是应该能应付大部分情况

后记

最近对群 bot 比较感兴趣,就自学了一下 python 和 nb2 的知识,尝试写一下可以帮助自己的插件
下一篇可以讲一下如何让用户输入附带参数,还有一些简单是例子

这篇关于nonebot2 插件编写指南(初级)(2.0.0a16之前)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/291185

相关文章

使用JavaScript将PDF页面中的标注扁平化的操作指南

《使用JavaScript将PDF页面中的标注扁平化的操作指南》扁平化(flatten)操作可以将标注作为矢量图形包含在PDF页面的内容中,使其不可编辑,DynamsoftDocumentViewer... 目录使用Dynamsoft Document Viewer打开一个PDF文件并启用标注添加功能扁平化

电脑显示hdmi无信号怎么办? 电脑显示器无信号的终极解决指南

《电脑显示hdmi无信号怎么办?电脑显示器无信号的终极解决指南》HDMI无信号的问题却让人头疼不已,遇到这种情况该怎么办?针对这种情况,我们可以采取一系列步骤来逐一排查并解决问题,以下是详细的方法... 无论你是试图为笔记本电脑设置多个显示器还是使用外部显示器,都可能会弹出“无HDMI信号”错误。此消息可能

如何安装 Ubuntu 24.04 LTS 桌面版或服务器? Ubuntu安装指南

《如何安装Ubuntu24.04LTS桌面版或服务器?Ubuntu安装指南》对于我们程序员来说,有一个好用的操作系统、好的编程环境也是很重要,如何安装Ubuntu24.04LTS桌面... Ubuntu 24.04 LTS,代号 Noble NumBAT,于 2024 年 4 月 25 日正式发布,引入了众

IDEA常用插件之代码扫描SonarLint详解

《IDEA常用插件之代码扫描SonarLint详解》SonarLint是一款用于代码扫描的插件,可以帮助查找隐藏的bug,下载并安装插件后,右键点击项目并选择“Analyze”、“Analyzewit... 目录SonajavascriptrLint 查找隐藏的bug下载安装插件扫描代码查看结果总结Sona

使用Java编写一个文件批量重命名工具

《使用Java编写一个文件批量重命名工具》这篇文章主要为大家详细介绍了如何使用Java编写一个文件批量重命名工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景处理1. 文件夹检查与遍历2. 批量重命名3. 输出配置代码片段完整代码背景在开发移动应用时,UI设计通常会提供不

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达+深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博客Nav2代价地图实现和原理–Nav2源码解读之CostMap2D(上)-CSDN博客往期教程: 第一期:基于UE5和ROS2的激光雷达+深度RG

如何编写Linux PCIe设备驱动器 之二

如何编写Linux PCIe设备驱动器 之二 功能(capability)集功能(capability)APIs通过pci_bus_read_config完成功能存取功能APIs参数pos常量值PCI功能结构 PCI功能IDMSI功能电源功率管理功能 功能(capability)集 功能(capability)APIs int pcie_capability_read_wo