example-code-2e/concurrency/wikipedia/daypicts_threads.py
2015-02-02 02:56:14 -02:00

46 lines
1.0 KiB
Python

"""
Wikipedia Picture of the Day (POTD) download example
"""
import sys
from concurrent import futures
from daypicts import main, get_picture_url, NoPictureForDate
MAX_NUM_THREADS = 400
GLOBAL_TIMEOUT = 300 # seconds
def get_picture_urls(dates, verbose=False):
num_threads = min(len(dates), MAX_NUM_THREADS)
pool = futures.ThreadPoolExecutor(num_threads)
pending = {}
for date in dates:
job = pool.submit(get_picture_url, date)
pending[job] = date
urls = []
count = 0
# get results as jobs are done
for job in futures.as_completed(pending, timeout=GLOBAL_TIMEOUT):
try:
url = job.result()
except NoPictureForDate as exc:
if verbose:
print('*** {!r} ***'.format(exc))
continue
count += 1
if verbose:
print(format(count, '3d'), end=' ')
print(url.split('/')[-1])
else:
print(url)
urls.append(url)
return urls
if __name__ == '__main__':
main(sys.argv[1:], get_picture_urls)