基本API

1、页面刷新    driver.fresh()

2、页面切换   driver.back().  driver.forward()

3、设置窗口大小    driver.set_window_size(540,960)      driver.maximize_window()

4、截屏     driver.get_screenshot_as_file("D:\\test\\b1.jpg")

5、退出     driver.close()用于关闭当前窗口。   driver.quit()用于结束进程,关闭所有窗口最后测试结束,要用quit,quit可以回收c盘的临时文件

常用的18种元素定位

1、find_element_by_name()

2、find_element_by_class_name()

3、find_element_by_id()

4、find_element_by_tag_name()

5、find_element_by_link_text()

6、find_element_by_partial_link_text()

7、find_element_by_xpath().  xpath索引从1开始算起

8、find_element_by_css_selector()

还有8种是上述方法的复数方法,其余两种是参数化的方法。

1、find_element(by="id",value="non")

2、find_elements(by="id",value="non")

xpath的模糊定位

1、driver.find_element_by_xpath("//*[contains(text(),'hao123')]").click()     xpath模糊匹配功能

2、driver.find_element_by_xpath("//*[contains(@id,"kw")]").click()。 xpath匹配某个属性

3、driver.find_element_by_xpath("//*[starts_with(@id,"kw")]").click()。xpath匹配以什么开头

4、driver.find_element_by_xpath("//*[ends_with(@id,"kw")]").click()。xpath匹配以什么结尾

5、driver.find_element_by_xpath("//[matchs(text(),"hao123")]").click()。xpath匹配正则表达式

css的定位

css可以通过元素的id,class,标签这三个常规属性直接定位到

用#表示id 如#kw

用.表示class  如.s_ipt

直接用标签名称,无任何标识符,如input

driver.find_element_by_css_selector("#kw").click()

css也可以用其他属性来表示,如:

driver.find_element_by_css_selector("[name='wd']").click()

driver.find_element_by_css_selector("[autocomplete='of']").click()

driver.find_element_by_css_selector("[type='text']").click()

css页可以通过标签与属性的组合来定位元素

driver.find_element_by_css_selector("input.s_ipt").click().    标签与class组合定位

driver.find_element_by_css_selector("input#kw").click()。    标签与id组合定位

driver.find_element_by_css_selector("input[name="kw"]").click。  标签与其他属性组合定位

css层级关系(和xpath一样)

driver.find_element_by_css_selector("form.fm>span>input").  class属性为fm的form标签下的span标签下的input标签

css索引(nth-child(1)来定位子元素,与xpath写法有差异,直接翻译过来就是第几个小孩)

driver.find_element_by_css_selector("select#nr>option:nth-child(1)").click()

css逻辑(与xpath不同的是,不用写and)

driver.find_element_by_css_selector("input[id='lw'][name='wd']")

多窗口、句柄(handle)

有些页面的链接打开后,会重新打开一个窗口,对于这种情况,想在新页面上操作,就得先切换窗口。获取窗口的唯一标识用句柄表示,所以只需要切换句柄,我们就能在多个页面上灵活自如的操作了。

获取当前页面的句柄:driver.current_window_handle

获取所有句柄:driver.window_handles

切换句柄:方法一(不推荐):1、循环判断是否与首页句柄相等  2、如果不等,说明是新页面的句柄 3、获取的新页面句柄后,可以切换到新打开的页面上 4、打印新页面的title,看是否切换成功

for i in all_h:

  if i != h:

    driver.switch_to.window(i)

    print driver.title

方法二:1、直接获取all_h这个list数据里面第二个handle的值 all_h[1]

driver.switch_to_window(all_h[1])

print driver.title

iframe(内嵌框架)

切换iframe1、首先定位到iframe上2、用switch_to_frame方法切换,可以直接用id定位切换

例如:driver.switch_to.frame(“x-URS-iframe”)

这里iframe的切换是默认支持id和name的方法的,当然也有没有id属性和name属性为空的情况,这时候就需要先定位iframe元素对象

例如 iframe=driver,find_element_by_tag_name("iframe")      driver.switch_to_frame(iframe)

当iframe上的操作完成后,想重新回到主页面上操作元素,这时候,就可以用switch_to_default_content()方法返回到主页面

select下拉框

1、二次定位基本思路,先定位select框,再定位select里的选项

2、直接定位基本思路,直接firebug选项

3、select模块基本思路,先要导入select方法;from selenium.webdriver.support.select import Select  然后通过select选项的索引来定位选择对应选项(从0开始技术),如选择第三个选项:select_by_index(2)

还可以通过选项的value值来定位   select_by_value("20")

还可以通过text直接定位   select_by_visible_text("每条显示50条")

select_by_index()  :通过索引定位    select_by_value()  :通过value值定位     select_by_visible_text() :通过文本值定位     deselect_all() :取消所有选项

deselect_by_index() :取消对应index选项    deselect_by_value() :取消对应value选项     deselect_by_visible_text() :取消对应文本选项
first_selected_option() :返回第一个选项    all_selected_options() :返回所有的选项

alert\confirm\prompt

不是所有的弹出框都叫alert,在使用alert方法之前,先要识别出到底是不是alert,这些弹出框操作主要方法有:text:获取文本值   accept():点击“确认”  dismiss():点击“取消”或者叉掉对话框

send_keys():输入文本值,仅限于prompt,在alert和confirm上没有输入框

alert操作:1、先用switch_to_alert()方法切换到alert弹出框上   2、可以用text方法获取弹出的文本信息  3、accept()点击确认按钮  4、dismiss()相当于点右上角x,取消弹出框

confirm操作:1、先用switch_to_alert()方法切换到alert弹出框上   2、可以用text方法获取弹出的文本信息  3、accept()点击确认按钮  4、dismiss()相当于点击取消按钮或右上角X,取消弹出框

prompt操作:1、先用switch_to_alert()方法切换到alert弹出框上   2、可以用text方法获取弹出的文本信息  3、accept()点击确认按钮  4、dismiss()相当于点击取消按钮或右上角X,取消弹出框  5、send_keys()这里多个输入框,可以用send_keys()方法输入文本内容

单选框和复选框

单选:radio    直接定位选中项即可

复选框:checkbox  直接定位选中项即可   如果全部勾选,可以用到定位一组元素(find_elements是不能直接点击的,它是复数的,所以只能先获取到所有的对象,然后通过for循环一个个去点击)

判断是否选中:is_select()     返回结果为布尔类型,没点击时候返回false,点击后返回true

table表格定位

在web页面后台通常会遇到table表格:xpath定位table

这里定位的格式是固定的,只需修改tr和td后面的数字就可以了,如第二行第一列tr[2]td[1]

打印表格内容:定位到表格内文本值,然后打印出来,print t.text

加载Firefox配置

1、找到firefox的配置文件,打开Firefox点右上角设置》?》故障排除信息》显示文件夹2、打开或把路径复制下来3、启动配置文件(转义字符)profile_directory=r"C:\Users\ruoyao\AppData\Roaming\Mozilla\Firefox\Profiles\yj6ubnq3.default"

加载配置 profile = webdriver.FirefoxProfile(profile_directory)

启动配置 driver = webdriver.Firefox(profile)

上传图片

定位到上传按钮,使用SendKeys.SendKeys("D:\\images.jpg")   SendKeys.SendKeys("{ENTER}")

文件上传

一种是input标签,一种是非input标签;input标签借用send_keys()即可;非input标签需借助SendKeys库

获取输入框的文本

drover.find_element_by_id("").get_attribute("value")

cookie

get_cookies()获取所有的cookie  get_cookie(name)获取指定的cookie delete_cookie(name)删除cookie

delete_all_cookies()删除所有cookies  add_cookie(cookie_dict)添加cookie,用于绕过验证码登录,用fiddler抓包查看登录前后多余的cookie值,获取网页,添加多余的cookie,即可绕过验证码登录成功,登录的时候要勾选下次自动登录按钮

webdriver的API的更多相关文章

  1. WebDriver基本API使用(基于Java)V1.0

    WebDriver基本API使用(基于Java)V1.0http://www.docin.com/p-803032877.html

  2. WebDriver基本API使用手册(基于Java和C#)

    WebDriver基本API使用手册(基于Java和C#) http://www.docin.com/p-747728551.html

  3. java webdriver的api的封装

    我们来看一下官网提供的代码写法,即最原始的写法: driver.findElement(By.id("kw")).click() 这样写是没任何问题的,但这样没有把元素对象,数据, ...

  4. Selenium 安装与配置及webdriver的API与定位元素

    1. selenium安装命令行 C:\Users\wu>cd /d E:\soft\python3.6\Scripts E:\soft\python3.6\Scripts>pip3 in ...

  5. Webdriver之API详解(3)

    前言 前两篇API链接 https://www.cnblogs.com/linuxchao/p/linuxchao-selenium-apione.html https://www.cnblogs.c ...

  6. Webdriver之API详解(2)

    前言:今天继续上一篇文章https://www.cnblogs.com/linuxchao/p/linuxchao-selenium-apione.html分享selenium' webdriver ...

  7. Webdriver之API详解(1)

    说明 Webdriver API详解,基于python3,unittest框架,driver版本和浏览器自行选择. 本内容需要对python3的unittest框架有一个简单的了解,这里不再赘述,不了 ...

  8. webdriver常用API

    本章涉及Selenium WebDriver的所有接口. Recommended Import Style 推荐的导入风格如下: from selenium import webdriver 然后,你 ...

  9. Python+Selenium(webdriver常用API)

    总结了Python+selenium常用的一些方法函数,以后有新增再随时更新: 加载浏览器驱动: webdriver.Firefox() 打开页面:get() 关闭浏览器:quit() 最大化窗口:  ...

随机推荐

  1. AJax与Jsonp跨域访问

    一.JavaScript的AJax AJAX即"Asynchronous Javascript And XML"(异步JavaScript和XML) 设计AJax使用的一种重要技术 ...

  2. 使用Fiddler调试线上JS代码

    在下面的命令框输入“select script”回车来筛选js请求 将HTTP请求重定向到本地的文件,进行web调试.这种调试方式不需要发布到线上再验证,避免了修改不成功.对用户造成影响的风险 左边一 ...

  3. 用JavaCV改写“100行代码实现最简单的基于FFMPEG+SDL的视频播放器 ”

    FFMPEG的文档少,JavaCV的文档就更少了.从网上找到这篇100行代码实现最简单的基于FFMPEG+SDL的视频播放器.地址是http://blog.csdn.net/leixiaohua102 ...

  4. css3兼容代码

    1. 渐变:.gradient{ width:300px; height:150px; filter:alpha(opacity=100 finishopacity=50 style=1 startx ...

  5. 拖拽 支持ie6

    可随意拖拽方块至任一位置: 1.setCapture方法:多用于容器对象,效果是对指定的对象设置鼠标捕获.使在容器内的子对象的鼠标事件均由容器对象触发,因此,只能在容器对象的鼠标事件函数中进行处理.当 ...

  6. Python 数据库连接池

    python编程中可以使用pymysql进行数据库连接及增删改查操作,但每次连接mysql请求时,都是独立的去请求访问,比较浪费资源,而且访问数量达到一定数量时,对mysql的性能会产生较大的影响.因 ...

  7. win7(64位)+vs2008配置Directshow

    参考链接:http://zhuyanfeng.com/archives/1663 PC环境:win7 64bit + vs2008 1.下载64位的win7 SDK2.安装过程中遇到错误(必须要卸载v ...

  8. js 代码风格(2)

    Properties    • 当访问属性的时候,我们使用点(.)操作符. var luke = { jedi: true, age: 28 }; // bad var isJedi = luke[' ...

  9. ipv6修改DNS服务-首选DNS服务器:240c::6666

    下一代互联网国家工程中心推出的IPv6 DNS服务 首选DNS服务器:240c::6666 备用DNS服务器:240c::6644   来自下一代互联网国家工程中心官网消息显示,日前,下一代互联网国家 ...

  10. VC++ Debug产生异常时中断程序执行Break on Exception

    It is possible to instruct the debugger to break when an exception occurs, before a handler is invok ...