多线程,进程实现并发请求


'''方式一:线程池的方式'''
# from concurrent.futures import ThreadPoolExecutor
# import requests
# import time
#
#
# def task(url):
# response=requests.get(url)
# print(url,response)
#
#
# pool=ThreadPoolExecutor(7)
#
#
# url_list=[
# 'http://www.baidu.com',
# 'http://www.baidu.com',
# 'http://www.baidu.com',
# 'http://www.baidu.com',
# ]
#
#
# for url in url_list:
# pool.submit(task,url)
# pool.shutdown(wait=True)





'''编写方式二'''

from concurrent.futures import ThreadPoolExecutor,ProcessPoolExecutor##前面是多线程,后面是多进程
import requests
import time


'''(url,response)当返回一个参数的时候,就会被当做一个整体进行返回,就是一个参数'''
def task(url):
'''下载页面'''
response=requests.get(url)
# print(url,response)
# return (url,response)##在这里进行返回值回去,当有返回值的时候,在下面的return_obj里面可以被接收到,就可以打印出来
return response##在这里进行返回值回去,当有返回值的时候,在下面的return_obj里面可以被接收到,就可以打印出来



'''arg是放列表和字典的 '''
def done(return_obj,*args,**kwargs):
response=return_obj.result()
# print(response)
print(response.status_code)###返回状态码
# print(response.content)
# print(args)
# print(kwargs)


pool=ThreadPoolExecutor(7)


url_list=[
'http://www.baidu.com',
'http://www.baidu.com',
'http://www.baidu.com',
'http://www.baidu.com',
]


for url in url_list:
v=pool.submit(task,url)
v.add_done_callback(done)##当执行完上面的程序的时候,就会自动执行回调函数
pool.shutdown(wait=True)

转载于:https://www.cnblogs.com/yunxintryyoubest/p/10033095.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值