Зазвичай спосіб зробити це - використовувати пул потоків і завантаження в чергу, які видають сигнал, який називається подією, коли це завдання закінчує обробку. Ви можете зробити це в рамках потокового модуля, який надає Python.
Для виконання зазначених дій я б використовував об’єкти подій та модуль Черги .
Однак, швидку і брудну демонстрацію того, що ви можете зробити за допомогою простої threading.Thread
реалізації, можна переглянути нижче:
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()
Можливо, було б сенсом не опитувати, як я роблю вище. У такому випадку я б змінив код на такий:
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()
Зверніть увагу, що тут немає встановленого прапора демона.
import threading, time; wait=lambda: time.sleep(2); t=threading.Thread(target=wait); t.start(); print('end')
). Я сподівався, що "фон" мав на увазі також відокремленість.