我尝试使该机器人具有线程,以便每24小时执行一次没有任何命令的almanax协程,但是当我尝试在另一个线程中这样调用它时,出现错误(TypeError:almanax()丢失1必需的位置参数:'ctx'),它需要ctx,我已经尝试过,但是我只是被卡住了。我完全是新手。
import discord
from discord.ext import commands
import urllib.request
import re
import datetime
from bs4 import BeautifulSoup
import requests
import asyncio
bot = commands.Bot(command_prefix='-', description= "Este es un DuckBot")
sourceLinkAlmanax = 'http://www.krosmoz.com/es/almanax'
fechaexacta = '{0:%d-%m-%Y}'.format(datetime.datetime.now())
async def dailyAlmanax():
while 1:
await asyncio.sleep(5) #86400
await almanax()
@bot.command()
async def almanax(ctx):
print("Procesando almanax")
source = requests.get(sourceLinkAlmanax).text
soup = BeautifulSoup(source, 'lxml')
mision = soup.find('div', class_='mid').p.text
bonus = soup.find('div', class_='more').getText()
ofrenda = soup.find('div', class_='more-infos-content').p.text
bonus = bonus.replace(mision, "")
bonus = bonus.replace(ofrenda, "")
linkImagen = soup.find('div', {"class": "more-infos"}).img['src']
fechaexacta = '{0:%d-%m-%Y}'.format(datetime.datetime.now())
mensaje = discord.Embed(title = "`Duckmanax del " + fechaexacta + "`", url=sourceLinkAlmanax, color=0xe5be01)
mensaje.add_field(name="Mision: ", value=f"{mision}", inline=False)
mensaje.add_field(name="Bonus: ", value=f"{bonus.strip()}", inline=False)
mensaje.add_field(name="Ofrenda: ", value=f"{ofrenda.strip()}", inline=False)
mensaje.set_image(url=linkImagen)
await ctx.send(embed = mensaje)
print("Almanax enviado")
@bot.command()
async def salmanax(ctx, busqueda: str):
print("Procesando busqueda de almanax")
fecha = datetime.datetime.now()
año = fecha.year
smes = fecha.month
sdia = fecha.day
for mes in range (smes,13):
if mes > smes:
sdia = 1
for dia in range (sdia,32):
print("Procesando Año:", año, "Mes:", mes, "Dia:", dia, "Buscando:", busqueda)
if mes < 10:
mes2 = "0" + str(mes)
else:
mes2 = mes
if dia < 10:
dia2 = "0" + str (dia)
else:
dia2 = dia
link = "http://www.krosmoz.com/es/almanax/" + str(año) + "-" + str(mes2) + "-" + str(dia2)
try:
data = urllib.request.urlopen(link).read().decode('utf-8')
except Exception as error:
pass
for linea in data.split("/n"):
try:
if re.findall(busqueda, linea, re.IGNORECASE):
await ctx.send("Encontre esta coincidencia de " + busqueda + " " + link)
except Exception as error2:
pass
print("Busqueda de almanax finalizada")
@bot.event
async def on_message(ctx):
if ctx.channel.name == 'almanax':
await bot.process_commands(ctx)
@bot.event
async def on_ready():
print("Bot listo")
await bot.change_presence(activity=discord.Streaming(name="-almanax",url="https://www.twitch.tv/kerdrai"))
bot.loop.create_task(dailyAlmanax())
bot.run(token)
命令要求传递Context对象,因此 可以await mycommand()
无效,除非您传递有效的上下文。并且[almanax()
命令中,它用在await ctx.send(embed = mesaje)
中,因此您不能只是组成一个新的Context对象并将其传递并期望它可以工作。 >您Bot.get_context()
方法,并将其作为参数传递给await almanax()
。这将导致每日邮件从引导您选择的邮件所在的频道。)来自almanax命令的整个部分
source = requests.get(sourceLinkAlmanax).text
to
mensaje.set_image(url=linkImagen)
可以外包到可以在almanax()
中调用的另一个函数中,我将调用该函数get_almanax()
(您应将其命名为async
,因为它依赖于等待响应),但是,您可以为其命名无论你想要什么。此函数返回在almanax()中发送的embed。然后,您可以将dailyAlmanax()
和almanax()
都更改为如下所示:
async def dailyAlmanax():
while 1:
await asyncio.sleep(5) #86400
mesaje = await get_almanax()
channel = bot.get_channel(ID) #ID for the daily almanax channel
await channel.send(embed = mesaje)
...
@bot.command()
async def almanax(ctx):
print("Procesando almanax")
mesaje = await get_almanax()
await ctx.send(embed = mesaje)
get_almanax()
函数应该定义为我之前提到的行,以及您需要的任何输入(看起来没有必要,但以防万一,它应该返回所需的嵌入。)>