不和谐重写机器人在上传到 heroku 后崩溃



到目前为止,它在heroku和本地都可以正常工作。现在它只能在本地工作,但在 heroku 上部署后不起作用。这是来自Heroku的日志:

2021-05-11T14:24:06.000000+00:00 app[api]: Build succeeded
2021-05-11T14:24:06.163275+00:00 heroku[worker.1]: State changed from starting to up
2021-05-11T14:24:15.306244+00:00 app[worker.1]: Traceback (most recent call last):
2021-05-11T14:24:15.306768+00:00 app[worker.1]: File "/app/dbot.py", line 2, in <module>
2021-05-11T14:24:15.307297+00:00 app[worker.1]: import discord
2021-05-11T14:24:15.307369+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.9/site-packages/discord/__init__.py", line 23, in <module>
2021-05-11T14:24:15.307970+00:00 app[worker.1]: from .client import *
2021-05-11T14:24:15.307996+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.9/site-packages/discord/client.py", line 36, in <module>
2021-05-11T14:24:15.308464+00:00 app[worker.1]: from .user import User
2021-05-11T14:24:15.308533+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.9/site-packages/discord/user.py", line 26, in <module>
2021-05-11T14:24:15.309148+00:00 app[worker.1]: import discord.abc
2021-05-11T14:24:15.309214+00:00 app[worker.1]: File "/app/.heroku/python/lib/python3.9/site-packages/discord/abc.py", line 101, in <module>
2021-05-11T14:24:15.309876+00:00 app[worker.1]: SnowflakeTime = Union[Snowflake, datetime]
2021-05-11T14:24:15.310045+00:00 app[worker.1]: NameError: name 'datetime' is not defined
2021-05-11T14:24:15.685219+00:00 heroku[worker.1]: Process exited with status 1
2021-05-11T14:24:15.995755+00:00 heroku[worker.1]: State changed from up to crashed

我有我的要求.txt文件,其中包含这些依赖项:

git+https://github.com/Rapptz/discord.py
youtube_dl==2020.03.08
pynacl == 1.3.0
colorlog == 4.1.0

我的文件里有这个:

worker: python dbot.py

我知道它说没有定义"日期时间",但这是我的主要 python 文件中的前几行:

import datetime
import discord
from discord.ext import commands
from discord import FFmpegPCMAudio
import random
import youtube_dl
import os
from discord.utils import get
import ctypes
import ctypes.util

至于我的知识,这一切都是在我将以下事件添加到我的代码之后开始的:

@client.event
async def on_message(ctx):
try:
if ctx.channel.name == "memes" and "https://" not in str(ctx.content) and not ctx.attachments:
await ctx.channel.purge(limit=1)
else:
await client.process_commands(ctx)
except:
await client.process_commands(ctx)

git+https://github.com/Rapptz/discord.py是 discord.py 的开发分支,不要在生产中使用它。

git+https://github.com/Rapptz/discord.py@1.7.2

1.7.2 是最新版本。

或来自 PyPi

discord.py>=1.7.2

discord.py 在 PyPI 中可用,因此可以直接从 PyPI 下载。

前面的答案是导致该错误的正确答案,但您为 on_message 事件显示的内容也不正确。我建议阅读on_message的文档,看看它应该如何工作。

编辑:

它当前正在运行,因为您没有使用任何使用Context对象的东西。on_message采用discord.Message参数,而不是commands.Context参数。这意味着如果您尝试使用Context中的方法或属性,它将不起作用,因为Message是传递给on_message的参数。

例如,如果我尝试在您的代码中执行ctx.bot,它会给我一个错误,因为discord.Message没有机器人属性。现在您可能正在查看文档并想知道为什么它说ctx具有机器人属性,但是当您尝试它时它出错。出于这个原因,我建议将on_message参数更改为message调用,并将ctx的所有实例更改为message以避免以后的混淆。