异步ThreadPoolExecutor,ProcessPoolExecutor和方法下载国旗实例

原因:略

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值