Zwykle sposobem na to byłoby użycie puli wątków i pobrań kolejki, które spowodowałyby wysłanie sygnału, czyli zdarzenia, po zakończeniu przetwarzania tego zadania. Możesz to zrobić w ramach modułu obsługi wątków, który zapewnia Python.
Aby wykonać te czynności, użyłbym obiektów zdarzeń i modułu Queue .
threading.Thread
Poniżej można jednak zobaczyć szybką i brudną demonstrację tego, co można zrobić za pomocą prostej implementacji:
import os
import threading
import time
import urllib2
class ImageDownloader(threading.Thread):
def __init__(self, function_that_downloads):
threading.Thread.__init__(self)
self.runnable = function_that_downloads
self.daemon = True
def run(self):
self.runnable()
def downloads():
with open('somefile.html', 'w+') as f:
try:
f.write(urllib2.urlopen('http://google.com').read())
except urllib2.HTTPError:
f.write('sorry no dice')
print 'hi there user'
print 'how are you today?'
thread = ImageDownloader(downloads)
thread.start()
while not os.path.exists('somefile.html'):
print 'i am executing but the thread has started to download'
time.sleep(1)
print 'look ma, thread is not alive: ', thread.is_alive()
Prawdopodobnie rozsądnie byłoby nie sondować tak, jak robię powyżej. W takim przypadku zmieniłbym kod na ten:
import os
import threading
import time
import urllib2
class ImageDownloader(threading.Thread):
def __init__(self, function_that_downloads):
threading.Thread.__init__(self)
self.runnable = function_that_downloads
def run(self):
self.runnable()
def downloads():
with open('somefile.html', 'w+') as f:
try:
f.write(urllib2.urlopen('http://google.com').read())
except urllib2.HTTPError:
f.write('sorry no dice')
print 'hi there user'
print 'how are you today?'
thread = ImageDownloader(downloads)
thread.start()
thread.join()
Zauważ, że nie ma tu ustawionej flagi demona.
import threading, time; wait=lambda: time.sleep(2); t=threading.Thread(target=wait); t.start(); print('end')
). Miałem nadzieję, że „tło” sugerowało również brak relacji.