开发者社区> python之战> 正文

pyppeteer最为核心类Page的接口方法(下)

简介: 重要:因为同步公号的文章格式很难保证,所以后面文章选择性在其他平台同步,欢迎移步公众号(Python之战),每日更新原汁原味! 在上一篇《pyppeteer最为核心类Page的接口方法》讲了大部分pyppeteer的Page类的接口,与selenium相比增强了与页面js的交互功能,同时增加了设备的伪装和模拟能力,一方是因为pyppeteer库是源于puppeteer,而puppeteer是Google提供了一个js库,本身和js的交互性强,所以在页面交互上更深入。
+关注继续查看

重要:因为同步公号的文章格式很难保证,所以后面文章选择性在其他平台同步,欢迎移步公众号(Python之战),每日更新原汁原味!

在上一篇《pyppeteer最为核心类Page的接口方法》讲了大部分pyppeteer的Page类的接口,与selenium相比增强了与页面js的交互功能,同时增加了设备的伪装和模拟能力,一方是因为pyppeteer库是源于puppeteer,而puppeteer是Google提供了一个js库,本身和js的交互性强,所以在页面交互上更深入。

也正是因为更深的js交互,所以可以任意修改任何网站在源码中的爬虫检测方式,并且毫不费劲,关于淘宝登陆有一种实现方式是使用中间代理修改检测的js文件,使用pyppeteer之后就不用这么麻烦,可以直接将js代码写入网站加载的js文件中。

继续Page类的剩下一下方法:

协程方法 setJavaScriptEnabled(enabled:bool )**

设置JavaScript启用/禁用。

协程方法 setOfflineMode(enabled:bool )**

设置离线模式启用/禁用。

协程方法 setRequestInterception(value:bool )

启用/禁用请求拦截,激活请求拦截允许 Request类的 abort(), continue_()和 response()方法,这提供了修改页面发出的网络请求的功能。

协程方法 setUserAgent(userAgent:str )

设置要在此页面中使用的用户代理。

参数:

userAgent(str) - 要在此页面中使用的特定用户代理

协程方法 setViewport(viewport:dict )

设置视图,可用选项包括:

width (int):以像素为单位的页面宽度。

height (int):以像素为单位的页面高度。

deviceScaleFactor (float):默认为1.0。

isMobile(bool):默认为False。

hasTouch(bool):默认为False。

isLandscape(bool):默认为False。

协程方法 tap(select:str )

点击与之匹配的元素,类似手机上的触摸功能

参数:

selector(str) - 搜索要触摸的元素的选择器。

target

返回此页面创建的目标。

协程方法 title()

获取页面标题

touchscreen

获取Touchscreen对象

tracing

获取跟踪对象

协程方法 type(selector:str,text:str,options:dict = None, kwargs )**

在selector选择器处输入text,类似selenium的keys,如果没有元素匹配selector,报错PageError

url

获取此页面的URL

viewport

返回视图字典,返回与setViewport()相同的字典字段

waitFor(selectorOrFunctionOrTimeout:Union[str,int,float],options:dict = None, args,* kwargs )**

等待页面上匹配元素出现,注意第一个位置参数:

如果selectorOrFunctionOrTimeout是number(int或float),则将其视为超时(以毫秒为单位),这将返回将在超时后执行的future。

如果selectorOrFunctionOrTimeout是一个JavaScript函数字符串,则此方法是一个快捷方式waitForFunction()。

如果selectorOrFunctionOrTimeout是选择器字符串或xpath字符串,则此方法是waitForSelector()或 的快捷方式waitForXPath()。如果字符串以字符串开头//,则将字符串视为xpath。

Pyppeteer尝试自动检测功能或选择器,但有时会错过检测。如果不按预期工作,请使用waitForFunction()或waitForSelector()直接使用 。

参数:

selectorOrFunctionOrTimeout:xpath或函数字符串或timeout(毫秒)

args(Any) - 传递函数的参数。

可用选项:请参阅waitForFunction()或 waitForSelector()

返回:

返回等待的对象,该对象解析为成功值的JSHandle。

waitForFunction(pageFunction:str, options:dict = None, * args, ** kwargs )

等到函数执行完成并返回一个truthy值。

参数:

args(Any) - 传递给的参数pageFunction。

返回:

返回等待pageFunction返回真值时解析的等待对象 。它解决了一个 JSHandle真正的价值。

此方法接受以下选项:

polling(str | number):pageFunction 执行的间隔,默认为raf。如果polling是数字,则将其视为执行函数的间隔(以毫秒为单位)。如果polling是字符串,则它可以是以下值之一:

raf:不断执行pageFunction的 requestAnimationFrame回调。这是最紧密的轮询模式,适合观察样式变化。

mutation:执行pageFunction每个DOM突变。

timeout(int | float):等待的最长时间(以毫秒为单位)。默认为30000(30秒),通过0禁用超时。

协程方法 waitForNavigation(options:dict =None,** kwargs )**

等待导航,可用选项与goto()方法相同,这将返回Response当页面导航到一个新的URL或重载。当您运行将间接导致页面导航的代码时,它非常有用。如果由于使用History API而导航到其他锚点或导航 ,则导航将返回None。

navigationPromise = async.ensure_future(page.waitForNavigation())
await page.click('a.my-link')  # indirectly cause a navigation
await navigationPromise  # wait until navigation finishes
或者
await asyncio.wait([
    page.click('a.my-link'),
    page.waitForNavigation(),
])

注意:使用History API更改URL被视为导航。

协程方法 waitForRequest(urlOrPredicate:Union [str,Callable [[pyppeteer.network_manager.Request],bool]],options:Dict [KT,VT] = None,kwargs)**

等待请求

参数:urlOrPredicate - 要等待的URL或函数。

此方法接受以下选项:timeout(int | float):最长等待时间(以毫秒为单位),默认为30秒,传递0以禁用超时。

firstRequest = await page.waitForRequest('http://example.com/resource')
finalRequest = await page.waitForRequest(lambda req: req.url == 'http://example.com' and req.method == 'GET')
return firstRequest.url

协程方法 waitForResponse(urlOrPredicate:Union [str,Callable [[pyppeteer.network_manager.Response],bool]],options:Dict [KT,VT] = None, kwargs)**

等待响应

参数:urlOrPredicate - 要等待的URL或函数。

此方法接受以下选项:timeout(int | float):最长等待时间(以毫秒为单位),默认为30秒,传递0以禁用超时。

firstResponse = await page.waitForResponse('http://example.com/resource')
finalResponse = await page.waitForResponse(lambda res: res.url == 'http://example.com' and res.status == 200)
return finalResponse.ok

waitForSelector(selector:str, options:dict = None, ** kwargs )

等待页面上出现匹配的元素,如果在调用方法selector已经存在,该方法将立即返回。如果在timeout等待的毫秒之后没有出现,则该函数将引发错误。

参数:selector(str) - 要等待的元素的选择器。

返回:返回等待的对象,该对象在将选择器字符串指定的元素添加到DOM时解析。

选项:

visible(bool):等待元素存在于DOM中并且可见; 即没有或 CSS属性。默认为。display: nonevisibility: hiddenFalse

hidden(bool):等待在DOM中找不到元素或隐藏元素,即具有或CSS属性。默认为。display: nonevisibility: hiddenFalse

timeout(int | float):等待的最长时间(以毫秒为单位)。默认为30000(30秒),为0禁用超时。

waitForXPath(xpath:str,options:dict = None, kwargs )**

等到xpath页面上出现匹配的元素,如果调用方法的时刻xpath已经存在,则该方法将立即返回;如果在timeout等待毫秒后没有出现xpath ,则该函数将引发异常。

参数:xpath(str) - 要等待的元素的[xpath]。

返回:返回等待由xpath字符串指定的元素添加到DOM时解析的等待对象。

选项:

visible(布尔):等待元素存在于DOM并是可见的,即,没有或 CSS属性。默认为。display: nonevisibility: hiddenFalse

hidden(bool):等待在DOM中找不到元素或隐藏元素,即具有或CSS属性。默认为。display: nonevisibility: hiddenFalse

timeout(int | float):等待的最长时间(以毫秒为单位)。默认为30000(30秒),为0禁用超时。

workers

获取此页面的所有执行线程,web workers概念是解决客户端JavaScript无法多线程的问题,其定义的worker是指代码的并行线程,不过web worker处于一个自包含的环境中,无法访问主线程的window对象和document对象

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
13673 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
18686 0
List、Map、Set三个接口存取元素时,各有什么特点?
List以特定索引来存取元素,可以有重复元素。Set不能存放重复元素(用对象的equals()方法来区分元素是否重复)。Map保存键值对(key-value pair)映射,映射关系可以是一对一或多对一。
862 0
微信小程序:wx.getUserInfo 接口的变动与使用
在微信小程序开发中,获取用户信息是经常会用到的!在之前,我们直接调用wx.getUserInfo接口,就可以直接获取用户的信息,然而为了安全考虑,从2018年4月30号开始,wx.getUserInfo接口不能直接调用,需要使用 引导用户主动进行授权操作,意外就是来的这么突然,防不胜防!!!
3552 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
23683 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
13912 0
postman 接口返回值有多个相同key时(不唯一),怎么提取第2个value给下一接口调用?
postman 接口返回值有多个相同key时(不唯一),怎么提取第2个value给下一接口调用?
3547 0
收发现金红包之-红包页面支付接口(alipay.fund.coupon.order.page.pay)
该接口用于用户在商户PC页进行红包的发放,付款时会链接到支付宝PC登录页面进行登录和后续的支付,在支付成功后跳转回商户页。参数详情点击参考文档 我这边分享一下java版的示例供大家参考,适用于jdk版本1.
1453 0
+关注
python之战
专注python学习与应用擅长爬虫、web、全栈,专注RPA技术实施;(个人公号:Python之战)
90
文章
0
问答
来源圈子
更多
+ 订阅
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载