目录
操作测试对象
添加等待
打印信息
浏览器操作
浏览器前进
浏览器滚动条操作
定位一组元素
多层框架/窗口定位
层级定位
下拉框处理
alert、confifirm、prompt 的处理
submit 和 click之间有什么区别?
submit操作测试对象,必须将对应的操作对象/点击对象放到form标签中
而click页面上的所有节点都可以点击
selenium.webdriver.remote.webdriver.implicitly_wait(time_to_wait)
browser.implicitly_wait(30)示例:# coding = utf-8from selenium import webdriverimport time # 调入 time 函数browser = webdriver.Chrome()browser.get("http://www.baidu.com")browser.implicitly_wait(30) # 隐式等待 30 秒browser.find_element_by_id("kw").send_keys("selenium")browser.find_element_by_id("su").click()browser.quit()
获取url(getcurrenturl)
#coding = utf-8from selenium import webdriverdriver = webdriver.Chrome()driver.get('http://www.baidu.com')print(driver.current_url) # 打印 urlbrowser.maximize_window()
获取title(getTitle)
#coding = utf-8from selenium import webdriverdriver = webdriver.Chrome()driver.get('http://www.baidu.com')print(driver.title) # 把页面 title 打印出来
最大化(max)
browser.maximize_window()
#coding=utf-8from selenium import webdriverimport timebrowser = webdriver.Chrome()browser.get("http://www.baidu.com")print " 浏览器最大化 "browser.maximize_window() # 将浏览器最大化显示time.sleep(2)browser.find_element_by_id("kw").send_keys("selenium")browser.find_element_by_id("su").click()time.sleep(3)browser.quit()
设置大小(setSize)
browser.set_window_size(width, high)
#coding=utf-8from selenium import webdriverimport timebrowser = webdriver.Chrome()browser.get("http://www.baidu.com")time.sleep(2)# 参数数字为像素点print(" 设置浏览器宽 480 、高 800 显示 ")browser.set_window_size(480, 800)time.sleep(3)browser.quit()
全屏(fullScreen)
navagite.windows.forward
navagite.windows.back..
# 浏览器的前进browser.forward()# 浏览器的后退browser.back()
#coding=utf-8from selenium import webdriverimport timebrowser = webdriver.Chrome()# 访问百度首页first_url= 'http://www.baidu.com'print("now access %s" %(first_url))browser.get(first_url)time.sleep(2)# 访问新闻页面second_url='http://news.baidu.com'print("now access %s" %(second_url))browser.get(second_url)time.sleep(2)# 返回(后退)到百度首页print("back to %s "%(first_url))browser.back()time.sleep(1)# 前进到新闻页print("forward to %s"%(second_url))browser.forward()time.sleep(2)browser.quit()
# 将浏览器滚动条滑到最顶端document.documentElement.scrollTop=0# 将浏览器滚动条滑到最底端document.documentElement.scrollTop=10000# 将浏览器滚动条滑到最底端, 示例js="var q=document.documentElement.scrollTop=10000"driver.execute_script(js)其中, execute_script(script, *args) ,在当前窗口 / 框架同步执行 javaScript
#coding=utf-8from selenium import webdriverimport time# 访问百度driver=webdriver.Chrome()driver.get("http://www.baidu.com")# 搜索driver.find_element_by_id("kw").send_keys("selenium")driver.find_element_by_id("su").click()time.sleep(3)# 将页面滚动条拖到底部js="var q=document.documentElement.scrollTop=10000"driver.execute_script(js)time.sleep(3)# 将滚动条移动到页面的顶部js="var q=document.documentElement.scrollTop=0"driver.execute_script(js)time.sleep(3)driver.quit()
Checkbox checkbox
用浏览器打开这个页面我们看到三个复选框和两个单选框。下面我们就来定位这三个复选框。
#coding=utf-8from selenium import webdriverimport timeimport osdr = webdriver.Chrome()file_path = 'file:///' + os.path.abspath('checkbox.html')dr.get(file_path)# 选择页面上所有的 input ,然后从中过滤出所有的 checkbox 并勾选之inputs = dr.find_elements_by_tag_name('input')for input in inputs:if input.get_attribute('type') == 'checkbox':input.click()time.sleep(2)dr.quit()get_attribute:获得属性值。
多层框架/窗口定位
对于一个 web 应用,经常会出现框架( frame ) 或窗口( window )的应用,这也就给我们的定位带来了一定的困难。
- 定位一个frame :switch_to.frame(name_or_id_or_frame_element)
- 定位一个窗口window:switch_to.window(name_or_id_or_frame_element)
用以下HTML示例说明:
frame href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet" />frame
height="600">层级定位
有时候我们需要定位的元素没有直接在页面展示,而是需要对页面的元素经过一系列操作之后才展示出来,这个时候我们就需要一层层去定位.用以下 HTML 示例说明:Level Locate href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrapcombined.min.css" rel="stylesheet" />Level locate
href="#">Link1aria-labelledby="dLabel" id="dropdown1" >href="#">Link2aria-labelledby="dLabel" >href="#">Link2aria-labelledby="dLabel" >定位思路:
具体思路是:先点击显示出 1 个下拉菜单,然后再定位到该下拉菜单所在的 ul ,再定位这个 ul 下的某个具体的link 。在这里,我们定位第 1 个下拉菜单中的 Action 这个选项。#coding=utf-8 from selenium import webdriver from selenium.webdriver.support.ui import WebDriverWait import time import os dr = webdriver.Chrome() file_path = 'file:///' + os.path.abspath('level_locate.html') dr.get(file_path) #点击Link1链接(弹出下拉列表) dr.find_element_by_link_text('Link1').click() #在父亲元件下找到link 为Action 的子元素 menu = dr.find_element_by_id('dropdown1').find_element_by_link_text('Action') #鼠标定位到子元素上 webdriver.ActionChains(dr).move_to_element(menu).perform() time.sleep(2) dr.quit()
下拉框处理
下拉框是我们最常见的一种页面元素,对于一般的元素,我们只需要一次就定位,但下拉框里的内容需要进行两次定位,先定位到下拉框对下拉框进行操作后,再定位到下拉框内里的选项。用以下 HTML 示例说明:
现在我们来通过脚本选择下拉列表里的 $10.69#coding=utf-8 from selenium import webdriver import os,time driver= webdriver.Chrome() file_path = 'file:///' + os.path.abspath('drop_down.html') driver.get(file_path) time.sleep(2) #先定位到下拉框 m=driver.find_element_by_id("ShippingMethod") #再点击下拉框下的选项 m.find_element_by_xpath("//option[@value='10.69']").click() time.sleep(3) driver.quit()
这里可能和之前的操作有所不同,首先要定位到下拉框的元素,然后选择下拉列表中的选项进行点击操作。alert、confifirm、prompt 的处理
- text 返回alert/confifirm/prompt 中的文字信息
- accept 点击确认按钮
- dismiss 点击取消按钮,如果有的话
- send_keys 输入值,如果alert 没有对话框就不能用了,不然会报错
注意: switch_to.alert() 只能处理原生的 alert用以下 HTML 示例说明:
alert # -*- coding: utf-8 -*- from selenium import webdriver from time import sleep import os dr = webdriver.Chrome() file_path = 'file:///' + os.path.abspath('alert.html') dr.get(file_path) # 点击链接弹出alert dr.find_element_by_id('tooltip').click() sleep(2) alert = dr.switch_to.alert() alert.accept() sleep(2) dr.quit()alert
hover to see tooltip#接受警告信息 alert = dr.switch_to.alert() alert.accept() #得到文本信息打印 alert = dr.switch_to.alert() print alert.text #取消对话框(如果有的话) alert = dr.switch_to.alert() alert.dismiss() #输入值 alert = dr.switch_to.alert() alert.send_keys("hello word")