Discordia & multiprocessing pulsante uomo presente python

0

Domanda

stavo cercando di fare questa logica quindi, se ho ottenuto un messaggio di discordia che contiene "911" distrugge lo script o chiamate alcune funzioni e arrestare il timer im di fronte a un sacco di errori e non riesco a pensare a un modo adatto per farlo ...

qualsiasi aiuto ?

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

Migliore risposta

1

Quando si imposta una variabile all'interno di una funzione di default per l'ambito locale. Guardate questo esempio:

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

Provare on-line!

Questo sarà in uscita 1.

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

Provare on-line!

Questo sarà effettivamente errore, perché da quando si imposta a = 2 all'interno della funzione f, a diventa una variabile locale così print(a) errori, perché non è definita in quel punto.

Per ovviare a questo, mettere global a in cima alla vostra funzione. Nel tuo caso, fare global sign all'interno def on_message in questo modo:

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

Ora, quando sign = manager.bool(True) è stato impostato, non è che influenzano la variabile globale sign che il Timer è la lettura.

Inoltre, penso che avete bisogno di aggiungere @client.event sopra async def on_message come bene.

2021-11-23 23:20:31

grazie funziona così bene :)
Joseph Yosoevsky

In altre lingue

Questa pagina è in altre lingue

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