python实现并发获取html的几种方式
1.线程池
from concurrent.futures import ThreadPoolExecutor
import requests
from fake_useragent import UserAgent
def task(url):
res = requests.get(url,
headers={"User-Agent": UserAgent().chrome})
print(f"{url}--{res}")
url_list = ["http://www.baidu.com",
"http://www.acfun.cn",
"http://www.bilibili.com",
"http://www.zhihu.com",
"http://www.douban.com"]
executor = ThreadPoolExecutor(max_workers=3)
tasks = [executor.submit(task, url) for url in url_list]
executor.shutdown(wait=True)
2.asyncio+aiohttp
import asyncio
import aiohttp
async def task(url):
async with aiohttp.request("GET", url) as response:
res = await response.text()
print(res)
url_list = ["http://www.baidu.com",
"http://www.acfun.cn",
"http://www.bilibili.com",
"http://www.zhihu.com",
"http://www.douban.com"]
tasks = [task(url) for url in url_list]
loop = asyncio.get_event_loop()
loop.run_until_complete(asyncio.wait(tasks))
3.gevent
from gevent import monkey
monkey.patch_all()
import gevent
from fake_useragent import UserAgent
import requests
def task(url):
res = requests.get(url,
headers={"User-Agent": UserAgent().chrome})
res.encoding = res.apparent_encoding
print(f"{url}--{res.text}")
url_list = ["http://www.baidu.com",
"http://www.acfun.cn",
"http://www.bilibili.com",
"http://www.zhihu.com",
"http://www.douban.com"]
gevent.joinall([gevent.spawn(task, url) for url in url_list])
4.tornado
from tornado.httpclient import AsyncHTTPClient
from tornado.httpclient import HTTPRequest
from tornado import ioloop
from functools import partial
from fake_useragent import UserAgent
count = None
def handler_response(response):
global count
count -= 1
if response.error:
print("error")
else:
print(response.effective_url)
if count == 0:
ioloop.IOLoop.current().stop()
def func(url_list):
global count
count = len(url_list)
for url in url_list:
client = AsyncHTTPClient()
client.fetch(HTTPRequest(url, headers={"User-Agent": UserAgent().chrome}), callback=handler_response)
url_list = ["http://www.baidu.com",
"http://www.acfun.cn",
"http://www.bilibili.com",
"http://www.zhihu.com",
"http://www.douban.com"]
ioloop.IOLoop.current().run_sync(partial(func, url_list))
ioloop.IOLoop.current().start()
5. twisted
from twisted.internet import reactor # 事件循环(终止条件,所有的socket都已经移除)
from twisted.internet import defer # defer.Deferred 特殊的socket对象(不发请求,手动移除)
from twisted.web.client import getPage # 用于创建socket对象(下载完成,自动从事件循环中移除)
from fake_useragent import UserAgent
# 1. 利用getPage创建socket
# 2. 将socket添加到事件循环
# 3. 开始事件循环(内部发送请求,并接受相应。当所有的socket请求完成之后,终止事件循环)
@defer.inlineCallbacks # 添加到事件循环
def task(url):
# 创建socket,注意url要转换成字节。headers中的"User-Agent"也要是字节
d = getPage(bytes(url, encoding="utf-8"), headers={b"User-Agent": UserAgent().chrome})
# 获取到的html页面会自动传到response函数的第一个参数里面
d.addCallback(response)
yield d
def response(content):
print(str(content, encoding="utf-8"))
def done(*args):
reactor.stop()
url_list = ["http://www.baidu.com",
"http://www.acfun.cn",
"http://www.bilibili.com",
"http://www.zhihu.com",
"http://www.douban.com"]
defer_list = []
for url in url_list:
t = task(url)
defer_list.append(t)
# 监听defer_list里面的任务是否执行完毕
d = defer.DeferredList(defer_list)
#如果执行完毕,执行对应的回调函数
d.addBoth(done)
# 启动事件循环
reactor.run()
python实现并发获取html的几种方式的更多相关文章
- 获取Type的三种方式
using System;using UnityEngine; public class Type_Test : MonoBehaviour{ private void Awake() { ...
- java动态获取WebService的两种方式(复杂参数类型)
java动态获取WebService的两种方式(复杂参数类型) 第一种: @Override public OrderSearchListRes searchOrderList(Order_Fligh ...
- AngularJS中获取数据源的几种方式
在AngularJS中,可以从$rootScope中获取数据源,也可以把获取数据的逻辑封装在service中,然后注入到app.run函数中,或者注入到controller中.本篇就来整理获取数据的几 ...
- java 获取时间戳的三种方式
java 获取时间戳的三种方式 CreationTime--2018年7月13日16点29分 Author:Marydon 1.实现方式 方式一:推荐使用 System.currentTimeMi ...
- 【Struts2】Struts2获取session的三种方式
1.Map<String,Object> map = ActionContext.getContext().getSession(); 2.HttpSession session = S ...
- js获取时间戳的三种方式
js获取时间戳的三种方式 CreateTime--2018年5月23日08:44:10 Author:Marydon // 方式一:推荐使用 var timestamp=new Date().ge ...
- Struts2(四.注册时检查用户名是否存在及Action获取数据的三种方式)
一.功能 1.用户注册页面 <%@ page language="java" contentType="text/html; charset=UTF-8" ...
- HTTP获取信息的四种方式
HTTP 从网络获取信息的四种方式 GET GET指代你在浏览器中输入网址,浏览网站时做的事.例如,我们使用 http://www.baidu.com 的时候,可以将GET想象成他说:"hi ...
- SpringMVC获取参数的几种方式
前言: 年末了,忙了一年了却发现系统的整理的东西很少,一些基础的东西都未做整理,这里就将它随便整理一下,增加一些印象,当然在网上看到一些好的资料也会整理下来以备后用.今天整理一下springMVC获取 ...
随机推荐
- python基础之数据类型与变量patr1
1:编写for循环,利用索引遍历出每一个字符 msg='hello egon 666' 2:编写while循环,利用索引遍历出每一个字符 msg='hello egon 666' 3:msg='hel ...
- 9 Django 模型层(2) --多表操作
创建模型 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名和年龄. 作者详细模型:把作者的详情放到详情表,包含生日,手机号,家庭住址等信息.作者详情模型和作者模型之间是一对一的关系( ...
- WPF里ItemsControl的分组实现
我们在用到ItemsControl时,有时会用到分组,如ListBox,ListView,DataGrid.WPF的ItemsControl可以实现分组,是依托于GroupStyle,以ListBox ...
- webdriver--定位一组元素+iframe表单切换
定位一组元素:find_elements,返回的是list,所以可以用列表的索引对列表里的某个元素操作,也可以用for循环访问list,依次操作各元素 driver.find_elements_by_ ...
- 遍历两个自定义列表来实现字典(key:value)
#自定义key ${keys} create list key1 key2 key3 #自定义value ${values} create list v ...
- springboot11 JPA
一.JPA 1. JPA 介绍 JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到 ...
- Client does not support authentication protocol requested by server
关于由于版本号码不同而引起的 Client does not support authentication protocol requested by server 问题 搜索类似的问题,得到的答案类 ...
- 物联网第一次作业--我眼中的物联网——从认识RFID开始
无线射频识别技术(Radio FrequencyIdentification,简称:RFID)是一种非接触式的自动识别技术,其基本原理是利用射频信号和空间耦合(电感或电磁耦合)或雷达反射的传输特性,实 ...
- KVC 开发详情
目录 概述 KVC基本技术 KVC访问函数 KVC搜索顺序 KVC集合操作 一.概述 kvc全名是Key-value coding,kvc是一种通过字符串间接的访问oc对象的属性的一种技术. 一个oc ...
- P2857 [USACO06FEB]稳定奶牛分配Steady Cow Assignment
题目描述 Farmer John's N (1 <= N <= 1000) cows each reside in one of B (1 <= B <= 20) barns ...