La discordia y multiprocesamiento deadman interruptor de python

0

Pregunta

yo estaba tratando de hacer de esta lógica, así que si recibí un mensaje en discordia que contiene al "911" destruye la secuencia de comandos o llamadas de algunas de las funciones y detener el temporizador im enfrenta a una gran cantidad de errores y no puedo pensar en una manera apropiada de hacerlo ...

alguna ayuda ?

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

Mejor respuesta

1

Cuando se establece una variable dentro de una función, se forma predeterminada en el ámbito local. Mira este ejemplo:

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

Intentarlo en línea!

Esta salida será de 1.

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

Intentarlo en línea!

Esta realidad error, porque desde que se establecen a = 2 dentro de la función f, a se convierte en una variable local para print(a) errores porque no está definida en ese punto.

Para evitar esto, poner global a en la parte superior de su función. En su caso, hacer global sign dentro de def on_message así:

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

Ahora, cuando sign = manager.bool(True) se establece, no afectan a la variable global sign que el Timer es la lectura.

También, creo que usted necesita para agregar @client.event por encima de async def on_message así.

2021-11-23 23:20:31

gracias funciona tan bien :)
Joseph Yosoevsky

En otros idiomas

Esta página está en otros idiomas

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