A discórdia & multiprocessamento deadman mudar python

0

Pergunta

eu estava tentando fazer esta lógica, então, se eu tenho uma mensagem sobre a discórdia que contém "911" destrói o script ou chamadas de algumas funções e parar o temporizador im enfrentando uma série de erros e eu não consigo pensar em ofa maneira correta de fazê-lo ...

qualquer ajuda ?

from time import sleep
import discord
import multiprocessing

client = discord.Client()
manager = multiprocessing.Manager()
sign = manager.boolean(False)

def Timer(sign):
    for second in range(15):
        if sign == True:
            print("bloooock")
            break
        if sign == False:
            print("passsssss")
            sleep(1)
def discord_message(client, sign):
    @client.event
    async def on_ready():
        print('Logged on as', client)
    async def on_message(message):
        messageContent = message.content
        if len(messageContent) > 0:
            if messageContent == str("911"):
                sign = manager.bool(True)
    client.run('###')
if __name__ == '__main__':
    freeze_support()
    p1 = multiprocessing.Process(target=Timer, args=(sign,))
    p2 = multiprocessing.Process(target=discord_message, args=(client, sign,))
    p1.start()
    p2.start()
    p1.join()
    p2.join()
discord discord.py python python-3.x
2021-11-23 22:45:54
1

Melhor resposta

1

Quando você definir uma variável dentro de uma função, ele será o padrão para o âmbito local. Veja esse exemplo:

a = 1
def f(): a = 2
f()
print(a)

Experimentá-lo online!

Esta saída será 1.

a = 1
def f(): print(a); a = 2
f()
print(a)

Experimentá-lo online!

Isso realmente vai erro, porque desde que você definir a = 2 dentro da função f, a torna-se uma variável local para print(a) erros porque não é definida nesse ponto.

Para contornar esse problema, coloque global a no topo de sua função. No seu caso, fazer global sign dentro def on_message assim:

def discord_message(client, sign):
    ...
    async def on_message(message):
        global sign
        ...

Agora, quando sign = manager.bool(True) está sendo definido, não prejudicando a variável global sign qual o Timer é a leitura.

Também, eu acho que você precisa adicionar @client.event acima async def on_message bem.

2021-11-23 23:20:31

graças funciona tão bem :)
Joseph Yosoevsky

Em outros idiomas

Esta página está em outros idiomas

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................