原因:略
1.普通方法实现下载国旗
# coding=utf-8
import os
import time
import sys
import requests
POP20_CC = ('CN IN US ID BR PK NG BD RU JP MX PH VN ET EG DE IR TR CD FR').split()
BASE_URL = 'http://flupy.org/data/flags'
DEST_DIR = 'downloads/'
def save_flag (img, filename):
path = os.path.join(DEST_DIR, filename)
with open(path, 'wb')as fp:
fp.write(img)
def get_flag (cc):
url = '{}/{cc}/{cc}.gif'.format(BASE_URL, cc=cc.lower())
print(url)
resp = requests.get(url)
return resp.content
def flush ():
sys.stdout.flush()
def download_many (cc_list):
for cc in sorted(cc_list):
image = get_flag(cc)
flush()
save_flag(image, cc.lower() + '.gif')
return len(cc_list)
def main (download_many):
to = time.time()
count = download_many(POP20_CC)
elapsed = time.time()
msg = '\n{} flags downloaded in {:.2f}s'
print(msg.format(count, elapsed - to))
if __name__ == '__main__':
main(download_many)
输出:
http://flupy.org/data/flags/bd/bd.gif
http://flupy.org/data/flags/br/br.gif
http://flupy.org/data/flags/cd/cd.gif
http://flupy.org/data/flags/cn/cn.gif
http://flupy.org/data/flags/de/de.gif
http://flupy.org/data/flags/eg/eg.gif
http://flupy.org/data/flags/et/et.gif
http://flupy.org/data/flags/fr/fr.gif
http://flupy.org/data/flags/id/id.gif
http://flupy.org/data/flags/in/in.gif
http://flupy.org/data/flags/ir/ir.gif
http://flupy.org/data/flags/jp/jp.gif
http://flupy.org/data/flags/mx/mx.gif
http://flupy.org/data/flags/ng/ng.gif
http://flupy.org/data/flags/ph/ph.gif
http://flupy.org/data/flags/pk/pk.gif
http://flupy.org/data/flags/ru/ru.gif
http://flupy.org/data/flags/tr/tr.gif
http://flupy.org/data/flags/us/us.gif
http://flupy.org/data/flags/vn/vn.gif
20 flags downloaded in 76.91s
2.ProcessPoolExecutor: 进程池map的用法
# coding=utf-8
import os
import time
import sys
import requests
from concurrent.futures import ProcessPoolExecutor
POP20_CC = ('CN IN US ID BR PK NG BD RU JP MX PH VN ET EG DE IR TR CD FR').split()
BASE_URL = 'http://flupy.org/data/flags'
DEST_DIR = 'downloads/'
MAX_WORKERS = 20
def save_flag (img, filename):
path = os.path.join(DEST_DIR, filename)
with open(path, 'wb')as fp:
fp.write(img)
def get_flag (cc):
url = '{}/{cc}/{cc}.gif'.format(BASE_URL, cc=cc.lower())
print(url)
resp = requests.get(url)
return resp.content
def flush ():
sys.stdout.flush()
def download_one (cc):
image = get_flag(cc)
flush()
save_flag(image, cc.lower() + '.gif')
return cc
def download_many (cc_list):
workers = min(MAX_WORKERS, len(cc_list))
with ProcessPoolExecutor(workers) as executor:
res = executor.map(download_one, sorted(cc_list))
return len(list(res))
def main (download_many):
to = time.time()
count = download_many(POP20_CC)
elapsed = time.time()
msg = '\n{} flags downloaded in {:.2f}s'
print(msg.format(count, elapsed - to))
if __name__ == '__main__':
main(download_many)
输出:
http://flupy.org/data/flags/bd/bd.gif
http://flupy.org/data/flags/br/br.gif
http://flupy.org/data/flags/cd/cd.gif
http://flupy.org/data/flags/cn/cn.gif
http://flupy.org/data/flags/de/de.gif
http://flupy.org/data/flags/eg/eg.gif
http://flupy.org/data/flags/et/et.gif
http://flupy.org/data/flags/fr/fr.gif
http://flupy.org/data/flags/id/id.gif
http://flupy.org/data/flags/in/in.gif
http://flupy.org/data/flags/ir/ir.gif
http://flupy.org/data/flags/jp/jp.gif
http://flupy.org/data/flags/mx/mx.gif
http://flupy.org/data/flags/ng/ng.gif
http://flupy.org/data/flags/ph/ph.gif
http://flupy.org/data/flags/pk/pk.gif
http://flupy.org/data/flags/ru/ru.gif
http://flupy.org/data/flags/tr/tr.gif
http://flupy.org/data/flags/us/us.gif
http://flupy.org/data/flags/vn/vn.gif
20 flags downloaded in 41.36s
3.ThreadPoolExecutor:线程池 map的用法
# coding=utf-8
import os
import time
import sys
import requests
from concurrent.futures import ThreadPoolExecutor
POP20_CC = ('CN IN US ID BR PK NG BD RU JP MX PH VN ET EG DE IR TR CD FR').split()
BASE_URL = 'http://flupy.org/data/flags'
DEST_DIR = 'downloads/'
MAX_WORKERS = 20
def save_flag (img, filename):
path = os.path.join(DEST_DIR, filename)
with open(path, 'wb')as fp:
fp.write(img)
def get_flag (cc):
url = '{}/{cc}/{cc}.gif'.format(BASE_URL, cc=cc.lower())
print(url)
resp = requests.get(url)
return resp.content
def flush ():
sys.stdout.flush()
def download_one (cc):
image = get_flag(cc)
flush()
save_flag(image, cc.lower() + '.gif')
return cc
def download_many (cc_list):
workers = min(MAX_WORKERS, len(cc_list))
with ThreadPoolExecutor(workers) as executor:
res = executor.map(download_one, sorted(cc_list))
return len(list(res))
def main (download_many):
to = time.time()
count = download_many(POP20_CC)
elapsed = time.time()
msg = '\n{} flags downloaded in {:.2f}s'
print(msg.format(count, elapsed - to))
if __name__ == '__main__':
main(download_many)
输出:
http://flupy.org/data/flags/bd/bd.gif
http://flupy.org/data/flags/br/br.gif
http://flupy.org/data/flags/cd/cd.gif
http://flupy.org/data/flags/cn/cn.gif
http://flupy.org/data/flags/de/de.gif
http://flupy.org/data/flags/eg/eg.gif
http://flupy.org/data/flags/et/et.gif
http://flupy.org/data/flags/fr/fr.gif
http://flupy.org/data/flags/id/id.gif
http://flupy.org/data/flags/in/in.gif
http://flupy.org/data/flags/ir/ir.gif
http://flupy.org/data/flags/jp/jp.gif
http://flupy.org/data/flags/mx/mx.gif
http://flupy.org/data/flags/ng/ng.gif
http://flupy.org/data/flags/ph/ph.gif
http://flupy.org/data/flags/pk/pk.gif
http://flupy.org/data/flags/ru/ru.gif
http://flupy.org/data/flags/tr/tr.gif
http://flupy.org/data/flags/us/us.gif
http://flupy.org/data/flags/vn/vn.gif
20 flags downloaded in 4.94s