多线程 + 队列

文章目录


import re
import time
import requests
from threading import Thread
from queue import Queue


class Spider(Thread):
    def __init__(self, url_queue):
        Thread.__init__(self)
        self.url_queue = url_queue

    def run(self):
        while not self.url_queue.empty():
            url = self.url_queue.get()
            response = requests.get(url).content.decode('utf-8')
            title = re.findall(r'<title>(.*?)</title>', response)[0]
            print(title)



if __name__ == '__main__':
    t11 = time.time()
    url_list = ['http://www.baidu.com' for _ in range(50)]

    url_queue = Queue()

    for url in url_list:
        url_queue.put(url)

    t_list = []
    for _ in range(10):
        t1 = Spider(url_queue)
        t_list.append(t1)
        t1.start()

    # join 阻塞主进程
    for t in t_list:
        t.join()

    print(time.time()-t11)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值