前言 突然,想把所有之前未更新的常用Api操作、演示写出来,算是对API的一种完结吧。 下面按照Api模块来做逐一介绍。一、iframe操作 iframe识别: img1。png 语法: driver。switchto。frame(方式)1、常见处理方法三种index:下标name:id或name属性的值webelement:元素2、通过下标进入 进入第一个iframedriver。switchto。frame(0)3、通过id或name属性的值进入 通过id或name属性的值进入指定的iframedriver。switchto。frame(iframe)driver。switchto。frame(iframeName)4、通过iframe元素进入iframe 通过iframe元素进入指定iframeiframedriver。findelement(By。ID,iframe)driver。switchto。frame(iframe) 完整案例代码如下:fromseleniumimportwebdriverfromselenium。webdriver。common。byimportByfromwebdrivermanager。chromeimportChromeDriverManagerdriverwebdriver。Chrome(ChromeDriverManager()。install())driver。get(http:localhost:8080iframeDemo。html)通过下标进入framedriver。switchto。frame(0)通过id或name属性的值进入指定的iframedriver。switchto。frame(iframe)driver。switchto。frame(iframeName)通iframe元素进入iframeiframedriver。findelement(By。ID,iframe)driver。switchto。frame(iframe)driver。findelement(By。ID,user)。clear()driver。findelement(By。ID,user)。sendkeys(thisisaframetest!)print(driver。findelement(By。ID,user)。getattribute(value))二、select下拉框操作1、select控件识别 img3。png 常见操作有两种:一步到位,二次管控!2、一步到位 一步到位:直接定位元素点击即可,示例如下:一步到位,直接选择典韦driver。findelement(By。CSSSELECTOR,〔value3〕)。click()print(driver。findelement(By。CSSSELECTOR,〔value3〕)。text)3、二次管控 二次管控:先定位select框,再定位select里的选项,通过Select对象进行强转,来调用select控件中的Api来达到操作的目的。 常见操作方法:selectbyindex():通过下标选择对应项selectbyvalue():通过value选择对应项selectbyvisibletext():通过可见文本选择对应项 示例代码如下:selectSelect(driver。findelement(By。ID,select))选择第一个选项select。selectbyindex(0)调用firstselectedoption就能获取当前下拉框选中值啦print(select。firstselectedoption。text)sleep(2)选择典韦select。selectbyvalue(3)调用firstselectedoption就能获取当前下拉框选中值啦print(select。firstselectedoption。text)sleep(2)选择凯select。selectbyvisibletext(凯)调用firstselectedoption就能获取当前下拉框选中值啦print(select。firstselectedoption。text)4、遍历所有选项 示例代码如下:打印所有选项的textforoptioninselect。options:print(选项为:option。text) 完整代码示例:fromtimeimportsleepfromseleniumimportwebdriverfromselenium。webdriver。common。byimportByfromselenium。webdriver。support。selectimportSelectfromwebdrivermanager。chromeimportChromeDriverManagerdriverwebdriver。Chrome(ChromeDriverManager()。install())driver。get(http:localhost:8080SelectDemo。html)一步到位,直接选择典韦driver。findelement(By。CSSSELECTOR,〔value3〕)。click()print(driver。findelement(By。CSSSELECTOR,〔value3〕)。text)selectSelect(driver。findelement(By。ID,select))选择第一个选项select。selectbyindex(0)调用firstselectedoption就能获取当前下拉框选中值啦print(select。firstselectedoption。text)sleep(2)选择典韦select。selectbyvalue(3)调用firstselectedoption就能获取当前下拉框选中值啦print(select。firstselectedoption。text)sleep(2)选择凯select。selectbyvisibletext(凯)调用firstselectedoption就能获取当前下拉框选中值啦print(select。firstselectedoption。text)打印所有选项的textforoptioninselect。options:print(选项为:option。text)sleep(2) 关于Select模块的其他方法还有很多,其他方法,还请各位各位读者朋友自己去尝试,就不一一列举了!三、交互操作弹出框的处理1、弹出框分类: 弹出框分为两种,一种基于原生JavaScript写出来的弹窗,另一种是自定义封装好的样式的弹出框,即原生JavaScript写出来的弹窗,另一种弹窗用click()基本就能搞定。原生JavaScript写出来的弹窗又分为三种: alert img4。png confirm img5。png prompt img6。png2、弹窗处理常用方法: alertconfirmprompt弹出框操作主要方法有:driver。switchto。alert:切换到alert弹出框上alert。text:获取文本值accept():点击确认dismiss():点击取消或者关闭对话框sendkeys():输入文本值仅限于prompt,在alert和confirm上没有输入框 alert弹窗处理 示例代码如下:alert弹窗处理driver。findelement(By。ID,alert)。click()alertdriver。switchto。alertprint(alert。text)确定alert。accept()sleep(2) confirm弹窗处理 示例代码如下:dialog对话框处理driver。findelement(By。ID,dialog)。click()alertdriver。switchto。alertprint(alert。text)取消操作alert。dismiss()sleep(2) prompt弹窗处理弹窗输入框driver。findelement(By。ID,welcome)。click()alertdriver。switchto。alertprint(alert。text)alert。sendkeys(input框)alert。accept()sleep(2)print(alert。text)四、执行Js操作 在做web自动化时,有些情况selenium的api无法完成,需要通过第三方手段比如js来完成实现,比如去改变某些元素对象的属性或者进行一些特殊的操作,本文将来讲解怎样来调用JavaScript完成特殊操作。1、用法 driver。executescript(js语句)2、模拟场景 场景1 打开百度首页,并弹窗提示hellow,world!,关闭弹窗,控制台输出弹窗文本hellow,world!示例代码如下:执行js语句driver。executescript(alert(hellow,world!))alertdriver。switchto。alertprint(alert。text)确定alert。accept() 场景2示例代码如下:将百度按钮改成MyLoveelementdriver。findelement(By。ID,su);driver。executescript(document。getElementById(su)。setAttribute(value,MyLove);,element); 效果如下: 3、模拟滚动条操作 在写脚本时,总会遇到一种情况,就是当滚动拉倒最下面了,表单或者下拉框、按钮这些元素未在当前页面展示,而webdriver提供的方法都是操作当前页面可见的元素,这时我们使用JavaScript操作浏览器的滚动条,滚动后使页面元素可见,就可完成后面的元素操作了。 核心思路: 就是使用js去控制浏览器滚动条的位置,在使用selenium调用JavaScript操作js完成。 下面举例几种常用滚动条的js代码示例如下:拖动滚动条至底部document。documentElement。scrollTop10000window。scrollTo(0,document。body。scrollHeight)拖动滚动条至顶部document。documentElement。scrollTop0arguments〔0〕。scrollIntoView(false);左右方向的滚动条可以使用window。scrollTo(左边距,上边距)方法window。scrollTo(200,1000) 实际案例 以博客园我的文章列表页为例,来演示滚动条操作,具体代码如下:fromtimeimportsleepfromseleniumimportwebdriverfromselenium。webdriver。common。byimportByfromwebdrivermanager。chromeimportChromeDriverManagerdriverwebdriver。Chrome(ChromeDriverManager()。install())driver。get(https:www。cnblogs。comlongronglang)driver。maximizewindow()获取第一篇文章列表元素elementdriver。findelement(By。CSSSELECTOR,。forFlow〔rolearticle〕:nthoftype(1)。verticalmiddle)sleep(2)将页面滚动条拖到底部driver。executescript(window。scrollTo(0,document。body。scrollHeight))将滚动条滚动至第三篇文章列表位置driver。executescript(arguments〔0〕。scrollIntoView(true),element)sleep(2)将滚动条滚动到顶部driver。executescript(arguments〔0〕。scrollIntoView(false),element)sleep(2)将滚动条滚动到指定位置driver。executescript(window。scrollTo(200,1000))五、Cookie操作之完美绕过验证码 下面我们就使用cookie操作,绕过登录验证码 还是以博客园为例,下面本文来介绍下如何绕过下图验证码,进入博客园 图片1、工具准备Fiddler。exeIDEAEclipseselenium的cookie操作 如何操作? 看完之后,记得收藏转发。2、使用Fiddler抓包 一般登陆网站成功后,会生成一个已登录状态的cookie,那么只需要直接把这个值拿到,用selenium进行addCookie操作即可。 可以先手动登录一次,然后抓取这个cookie,这里我们就需要用抓包工具fiddler了 先打开博客园登录界面,手动输入账号和密码(不要点登录按钮) 图片 打开fiddler抓包工具,此时再点博客园登录按钮 图片 登录成功后,再查看cookie变化,发现多了两组参数,多的这两组参数就是我们想要的,copy出来,一会有用 图片3、cookie操作语法 driver。addcookie() addcookie(cookiedict)方法里面参数是cookiedict,说明里面参数是字典类型。 源码官方文档介绍:addcookie(self,cookiedict)Addsacookietoyourcurrentsession。Args:cookiedict:Adictionaryobject,withrequiredkeysnameandvalue;optionalkeyspath,domain,secure,expiryUsage:driver。addcookie({name:foo,value:bar})driver。addcookie({name:foo,value:bar,path:})driver。addcookie({name:foo,value:bar,path:,secure:True}) 从官方的文档里面可以看出,添加cookie时候传入字典类型就可以了,等号左边的是name,等号左边的是value。 把前面抓到的两组数据(参数不仅仅只有name和value),写成字典类型:{name:。CNBlogsCookie,value:2C3AE01E461B2D2F1572D02CB936D77A053089AA2xxxx。。。}{name:。Cnblogs。AspNetCore。Cookies,value:CfDJ8Mmb5OBERd5FqtiQlKZZIG4HKzZxxx。。。}4、完整示例代码coding:utf8fromseleniumimportwebdriverimporttimedriverwebdriver。Chrome()driver。maximizewindow()driver。get(https:www。cnblogs。comlongronglang)添加cookiec1{udomain:u。cnblogs。com,uname:u。CNBlogsCookie,uvalue:uxxxx,uexpiry:15412950521,upath:u,uhttpOnly:True,usecure:False}c2{udomain:u。cnblogs。com,uname:u。Cnblogs。AspNetCore。Cookies,uvalue:uxxxx,uexpiry:15412950521,upath:u,uhttpOnly:True,usecure:False}添加2个值driver。addcookie(c1)driver。addcookie(c2)time。sleep(3)刷新下页面就见证奇迹了driver。refresh()再来个登录后操作driver。findelementbylinktext(u博客园)。click()driver。findelementbylinktext(Refain)。click() 效果图 image。png 有几点需要注意:登录时候要勾选下次自动登录按钮。addCookie()只添加name和value,对于博客园的登录是不成功。本方法并不适合所有的网站,一般像博客园这种记住登录状态的才会适合。学习过程中有遇到疑问的,可以加我微信1399811201交流最后 本来想着一口气都写完的,结果时间不允许,今天先更新这么多了,996的工作情况,请原谅我的懒惰,您的转发、转发、点赞,我都当作了喜欢!