Voglio un processo a esecuzione prolungata per restituire il suo avanzamento su una coda (o qualcosa di simile) che alimenterò a una finestra di dialogo della barra di avanzamento. Ho anche bisogno del risultato quando il processo è completato. Un esempio di test qui non riesce con un RuntimeError: Queue objects should only be shared between processes through inheritance
.Come si passa un riferimento alla coda a una funzione gestita da pool.map_async()?
import multiprocessing, time
def task(args):
count = args[0]
queue = args[1]
for i in xrange(count):
queue.put("%d mississippi" % i)
return "Done"
def main():
q = multiprocessing.Queue()
pool = multiprocessing.Pool()
result = pool.map_async(task, [(x, q) for x in range(10)])
time.sleep(1)
while not q.empty():
print q.get()
print result.get()
if __name__ == "__main__":
main()
Sono stato in grado di ottenere questo al lavoro utilizzando oggetti singoli Process (dove io sto alowed a passare un riferimento coda), ma poi non ho un pool per gestire i molti processi che voglio lanciare. Qualche consiglio su un modello migliore per questo?
Non è una risposta alla tua domanda, ma prova la libreria 'execnet' per i mapping multi-processo. Il 'multiprocessing' incorporato ha alcuni problemi ancora da risolvere (vedi il tracker Python). Oltre a ciò il suo codice sorgente è abbastanza grande e complicato. La libreria 'execnet' mi sembra molto meglio di' multiprocessing'. –