Python Discord.py `time.sleep()` coroutine

末鹿安然 提交于 2021-02-05 08:09:40

问题


import discord

import os
import random
import time
import math


client = discord.Client()

with open('admins.conf', 'r') as f:
    for line in f.readlines():
        exec(line)
with open('bans.conf', 'r') as f:
    for line in f.readlines():
        exec(line)
with open('coins.conf', 'r') as f:
    for line in f.readlines():
        exec(line)

random.seed(os.urandom(32))
searchusers = []

@client.event
async def on_ready():
    '''Notification on ready.'''
    print('Logged in! Bot running.')
    await client.change_presence(activity=discord.Game(name='/help'))

def getcoins(uid):
    '''Get the amount of coins, if nonexistent set to 0.'''
    try:
        return coins[uid][0]
    except Exception:
        coins[uid] = [0, time.time()+20]
        return 0

def mention_to_uid(mention):
    '''Extract UID from a mention'''
    uid = mention[2:-1]
    if uid[0] == '!':
        uid = uid[1:]
    return uid

def setcoins(uid, value):
    '''Set the amount of coins someone has.'''
    try:
        coins[uid][0] = value
    except Exception:
        coins[uid] = [value, time.time()+20]
    with open('coins.conf','w') as f:
        f.write('coins = '+repr(coins))

@client.event
async def on_message(message):
    '''Main bot code running on message.'''
    if message.author == client.user:
        return
    if message.author.id in bans:
        return
    if message.content.startswith('/') or message.content.startswith('&'):
        user = message.author.id
        text = message.content[1:].strip()
        command = text.split(' ')[0]
        subcommand = text.split(' ')[1:]
        if message.author.id in searchusers:
            await message.channel.send('<@'+str(message.author.id)+'>, you cannot use bot commands while you are searching.')
            return

-------------------- snip --------------------

        if command == 'search':
            await message.channel.send('<@'+str(user)+'>, you have begun searching! It will take 2 minutes.')
            searchusers.append(user)
            time.sleep(59.99)
            await message.channel.send('<@'+str(user)+'>, there is 1 minute left.')
            time.sleep(39.99)
            await message.channel.send('<@'+str(user)+'>, there are 20 seconds left!')
            time.sleep(14.99)
            await message.channel.send('<@'+str(user)+'>, there are 5 seconds left!')
            time.sleep(4.99)
            found = random.randint(50, 120)
            await message.channel.send('<@'+str(user)+'>, you are done searching! You found '+str(found)+' coins!')
            setcoins(user, getcoins(user)+found)
            searchusers.remove(user)

During the time.sleep() events other bot commands do not register until the sleep function has passed. For example doing a command like /help right after doing /search the bot will not respond until after one minute, when it will respond to /help and message there is 1 minute left. I have tried sticking "await" before each one of the sleep functions but it just spit out runtime warnings at me and stopped the execution (It just says you started searching and then nothing happens).


回答1:


time.sleep() stops the entire execution of the program. If you just want to delay one async response thread use asyncio.sleep

Example:

import asyncio

async def wait():
    await asyncio.sleep(5)
    print('I waited 5 seconds')


来源:https://stackoverflow.com/questions/61147936/python-discord-py-time-sleep-coroutine

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!