使用进程池模拟多进程爬取url获取数据,使用进程绑定的回调函数去处理数据

 1 # 使用requests请求网页,爬取网页的内容
 2 
 3 # 模拟使用进程池模拟多进程爬取网页获取数据,使用进程绑定的回调函数去处理数据
 4 
 5 import requests
 6 from multiprocessing import Pool
 7 
 8 # response = requests.get('http://www.baidu.com') # 访问网页获取网页内容,得到一个网页内容的结果对象<Response [200]>这个200是一个状态码,200表示网页正常的返回,404表示网页找不到
 9 #
10 # print(response)
11 # print(response.status_code) # 获取访问网页返回的状态码,200表示网页正常返回,404表示网页找不到。这里是200
12 # print(response.__dict__)
13 # print(response.content) # 获取网页源码
14 
15 def get_url(url):
16     '''
17     爬取url、将url和url的源码返回
18     :param url:
19     :return:
20     '''
21     response = requests.get(url)
22     if response.status_code == 200:     # 200表示网页成功返回了,成功访问了网页
23         return url, response.content.decode('utf-8')     # 将网页的源码获取到,因为源码是bytes类型的,所以这里解码成了str
24 
25 def call_back(args):
26     '''
27     回调函数,接收获取get_url的返回值,处理获取到的网页数据
28     :param args: 参数不能是多个,所以想获取到多个参数,这里可以是元组的形式.接收的是get_url的返回值
29     :return:
30     '''
31     url, content = args
32     print(url, len(content))
33 
34 if __name__ == '__main__':
35     url_lst = [
36         'https://www.cnblogs.com',
37         'http://www.baidu.com',
38         'https://www.sogou.com',
39         'http://www.sohu.com'
40     ]
41     pool = Pool(4)
42     for url in url_lst:
43         pool.apply_async(get_url, args=(url, ), callback=call_back)
44     pool.close()
45     pool.join()

  回调函数:一般应用在进程的任务有延时,而要处理的数据时间的很短时,将进程的任务和回调函数绑定起来,将任务获取到的数据返回给回调函数,由回调函数处理数据,回调函数是在主进程中得以执行的

猜你喜欢

转载自www.cnblogs.com/whylinux/p/9839338.html