使用不带 cogs 的 discord.py 是否可以实现 OOP?

2022-01-15 00:00:00 python python-3.x discord discord.py

问题描述

最近几天,我一直在尝试将用 discord.py 编写的不和谐机器人的结构调整为更面向 OOP 的结构(因为周围有功能并不理想).

These last few days, I've been trying to adapt the structure of a discord bot written in discord.py to a more OOP one (because having functions lying around isn't ideal).

但我发现的问题比我想象的要多得多.问题是我想将所有命令封装到一个单个类中,但我不知道要使用哪些装饰器以及我必须继承哪些类以及如何继承.

But I have found way more problems that I could have ever expected. The thing is that I want to encapsulate all my commands into a single class, but I don't know what decorators to use and how and which classes I must inherit.

到目前为止,我所取得的成果是类似于下面的代码片段.它会运行,但在执行命令时会抛出类似

What I've achieved so far is code like the snippet down below. It runs, but at the moment of executing a command it throws errors like

discord.ext.commands.errors.CommandNotFound:命令状态"没找到

discord.ext.commands.errors.CommandNotFound: Command "status" is not found

我使用的是 Python 3.6.

I'm using Python 3.6.

from discord.ext import commands


class MyBot(commands.Bot):

    def __init__(self, command_prefix, self_bot):
        commands.Bot.__init__(self, command_prefix=command_prefix, self_bot=self_bot)
        self.message1 = "[INFO]: Bot now online"
        self.message2 = "Bot still online {}"

    async def on_ready(self):
        print(self.message1)

    @commands.command(name="status", pass_context=True)
    async def status(self, ctx):
        print(ctx)
        await ctx.channel.send(self.message2 + ctx.author)


bot = MyBot(command_prefix="!", self_bot=False)
bot.run("token")


解决方案

要注册命令你应该使用self.add_command(setup),但是你不能有self<setup 方法中的/code> 参数,因此您可以执行以下操作:

To register the command you should use self.add_command(setup), but you can't have the self argument in the setup method, so you could do something like this:

from discord.ext import commands
    
class MyBot(commands.Bot):
    
    def __init__(self, command_prefix, self_bot):
        commands.Bot.__init__(self, command_prefix=command_prefix, self_bot=self_bot)
        self.message1 = "[INFO]: Bot now online"
        self.message2 = "Bot still online"
        self.add_commands()
    
    async def on_ready(self):
        print(self.message1)
    
    def add_commands(self):
        @self.command(name="status", pass_context=True)
        async def status(ctx):
            print(ctx)
            await ctx.channel.send(self.message2, ctx.author.name)
        
        self.add_command(status)
    
bot = MyBot(command_prefix="!", self_bot=False)
bot.run("token")

相关文章