python+selenium自动测试之WebDriver的常用API(基础篇一)

基于python3.6,selenium3.141,详细资料介绍查看官方API文档,点击这里

一、对浏览器操作

 driver = webdriver.Chrome()  # 初始化chrome
driver1 = webdriver.Firefox() # 初始化Firefox
driver2 = webdriver.Ie() # 初始化IE
driver3 = webdriver.Edge() # # 初始化Edge
driver.get("https://www.baidu.com") # 打开url
driver.capabilities['version'] # 获取浏览器version
driver.maximize_window() # 将浏览器最大化显示
driver.set_window_size(480, 800) # 设置浏览器宽480、高800显示
driver.back() # 浏览器后退
driver.forward() # 浏览器前进
driver.title # 获取当前页面的title
driver.current_url # 获取当前页面的URL
driver.current_window_handle # 获取当前浏览器窗口的句柄
driver.close() # 关闭浏览器,关闭当前浏览器,即最上层那个
driver.quit() # 关闭webdriver打开的所有浏览器
各浏览器驱动下载地址,注意版本要对上
Chrome:http://npm.taobao.org/mirrors/chromedriver/
Edge:https://developer.microsoft.com/en-us/microsoft-edge/tools/webdriver/
Firefox:https://github.com/mozilla/geckodriver/releases
Safari:https://webkit.org/blog/6900/webdriver-support-in-safari-10/
IE:http://selenium-release.storage.googleapis.com/index.html

二、页面元素定位

最好使用id,name的方式定位元素,因为一般这两个元素是全局唯一的;有时候元素不唯一,推荐使用xpath或者css定位,根据个人喜好而定,不推荐使用class

 # return :WebElement - the element if it was found
driver.find_element(By.ID, 'foo')
driver.find_element_by_id("foo")
driver.find_element_by_name("foo")
driver.find_element_by_class_name("foo")
driver.find_element_by_tag_name("h1")
driver.find_element_by_link_text("Sign In")
driver.find_element_by_partial_link_text("Sign")
driver.find_element_by_xpath("//div/td[1]")
driver.find_element_by_css_selector("#foo")
 # return: list of WebElement - a list with elements if any was found. An empty list if not
driver.find_elements(By.CLASS_NAME, 'foo')
driver.find_elements_by_id("foo")
driver.find_elements_by_name("foo")
driver.find_elements_by_class_name("foo")
driver.find_elements_by_tag_name("h1")
driver.find_elements_by_link_text("Sign In")
driver.find_elements_by_partial_link_text("Sign")
driver.find_elements_by_xpath("//div[contains(@class, 'foo')]")
driver.find_elements_by_css_selector("#foo")

三、页面元素操作

 # 清除输入框的默认内容
driver.find_element_by_id("foo").clear()
# 输入框里输入context
driver.find_element_by_id("foo").send_keys("context")
# 单击一个按钮
driver.find_element_by_id("foo").click()
# 提交表单
driver.find_element_by_id("foo").submit()
# 返回元素的尺寸
driver.driver.find_element_by_id("foo").size
# 获取元素文本
driver.find_element_by_id("foo").text
# 返回元素的属性值,元素拥有的任意属性。如果是input的,可以通过获取value值获得当前输入的值
driver.find_element_by_id("foo").get_attribute('value')
# 返回元素的结果是否可见,返回结果为True或False
driver.find_element_by_id("foo").is_displayed()

四、鼠标事件

 from selenium.webdriver.common.action_chains import ActionChains
# 定位鼠标元素
mouse = driver.find_element_by_id("foo")
# 对定位到的元素执行鼠标右键操作
ActionChains(driver).context_click(mouse).perform()
# 对定位到的元素执行鼠标双击操作
ActionChains(driver).double_click(mouse).perform()
# 对定位到的元素执行鼠标移动到上面的操作
ActionChains(driver).move_to_element(mouse).perform()
# 对定位到的元素执行鼠标左键按下的操作,注意这里是点击下去不释放
ActionChains(driver).click_and_hold(mouse).perform() # 鼠标拖放操作
element = driver.find_element_by_id("foo1") # 定位元素的原位置
target = driver.find_element_by_id("foo2") # 定位元素要移动到的目标位置
ActionChains(driver).drag_and_drop(element, target).perform() # 执行元素的移动操作

五、键盘事件

 from selenium.webdriver.common.keys import Keys

 driver.find_element_by_id("foo").send_keys(Keys.BACK_SPACE)  # 删除键(BackSpace)
driver.find_element_by_id("foo").send_keys(Keys.SPACE) # 空格键(Space)
driver.find_element_by_id("foo").send_keys(Keys.TAB) # 制表键(Tab)
driver.find_element_by_id("foo").send_keys(Keys.ESCAPE) # 回退键(Esc)
driver.find_element_by_id("foo").send_keys(Keys.ENTER) # 回车键(Enter)
driver.find_element_by_id("foo").send_keys(Keys.DELETE) # 删除键(Delete)
driver.find_element_by_id("foo").send_keys(Keys.CONTROL, 'a') # 全选(Ctrl+A)
driver.find_element_by_id("foo").send_keys(Keys.CONTROL, 'c') # 复制(Ctrl+C)
driver.find_element_by_id("foo").send_keys(Keys.CONTROL, 'x') # 剪切(Ctrl+X)
driver.find_element_by_id("foo").send_keys(Keys.CONTROL, 'v') # 粘贴(Ctrl+V)
上一篇:从零开始学习 asp.net core 2.1 web api 后端api基础框架(二)-创建项目


下一篇:extends的使用