python已协程方式处理任务实现过程
2020-02-13 10:05
796 查看
这篇文章主要介绍了python已协程方式处理任务实现过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
#从genent中导入monky模块① from gevent import monkey #把程序变成协程的方式运行② monkey.patch_all() import gevent,requests,time #导入requests和time start = time.time() #记录程序开始时间 url_list = ['https://www.baidu.com/', 'https://www.sina.com.cn/', 'http://www.sohu.com/', 'https://www.qq.com/', 'https://www.163.com/', 'http://www.iqiyi.com/', 'https://www.tmall.com/', 'http://www.ifeng.com/'] #把8个网站封装成列表 def get_data(url): r = requests.get(url) # 用requests.get()函数爬取网站 print(url, time.time()-start,r.status_code) task_list=[] # 创建一个空列表 for url in url_list: # 用gevent里面的spawn函数创建任务 get_data是方法名,url是参数③ task=gevent.spawn(get_data,url) # 将创建的任务添加到task_list④ task_list.append(task) #执行任务列表中的所有任务⑤ gevent.joinall(task_list) end = time.time() #记录程序结束时间 print(end-start) #end-start是结束时间减去开始时间,就是最终所花时间。
使用队列,代码如下:
#从genent中导入monky模块① from gevent import monkey #把程序变成协程的方式运行② monkey.patch_all() import gevent,requests,time #从gevent库里导入queue模块 from gevent.queue import Queue #导入requests和time start = time.time() #记录程序开始时间 url_list = ['https://www.baidu.com/', 'https://www.sina.com.cn/', 'http://www.sohu.com/', 'https://www.qq.com/', 'https://www.163.com/', 'http://www.iqiyi.com/', 'https://www.tmall.com/', 'http://www.ifeng.com/'] #把8个网站封装成列表 #创建队列对象,并赋值给work。 work=Queue() for url in url_list: # 用put_nowait()函数可以把网址都放进队列里。 work.put_nowait(url) def get_data(): # 当队列不是空的时候,就执行下面的程序。 while not work.empty(): # 用get_nowait()函数可以把队列里的网址都取出。 url=work.get_nowait() r = requests.get(url) # 用requests.get()函数爬取网站 qsize队列长度 print(url, work.qsize(),r.status_code) task_list=[] # 创建一个空列表 # 创建了2个爬虫 for x in range(2): # 用gevent里面的spawn函数创建任务 get_data是方法名 task=gevent.spawn(get_data) # 将创建的任务添加到task_list④ task_list.append(task) #执行任务列表中的所有任务⑤ gevent.joinall(task_list) end = time.time() #记录程序结束时间 print(end-start) #end-start是结束时间减去开始时间,就是最终所花时间。
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- Python定时任务的实现方式
- Python3-定时任务四种实现方式
- python3.5进阶(三)-------------实现多任务之协程(生成器,迭代器)
- python网络-多任务实现之协程
- 详解python实现数据归一化处理的方式:(0,1)标准化
- python实现图片二值化及灰度处理方式
- Python四钟方式来实现“一次处理一个字符的方式处理字符串”
- Python3实现定时任务的四种方式
- 由于GIL,Python想做多任务,最好在多核上用多进程方式实现
- Python使用APScheduler实现定时任务过程解析
- Python协程操作之gevent(yield阻塞,greenlet),协程实现多任务(有规律的交替协作执行)用法详解
- Python定时任务的实现方式
- python协程的多种实现方式
- python epoll简单模型(协程的实现方式)
- Python实现定时执行任务的三种方式简单示例
- python实现多任务(三)—— 协程
- python实现协程方式的HTTP服务器,浏览器通过HTTP与之通信4
- python BlockingScheduler定时任务及其他方式的实现
- Python3定时任务实现方式
- Python3中常用的处理时间和实现定时任务的方法的介绍