Selenium自动化测试

Selenium自动化测试第一天(上)

2018-12-19  本文已影响523人  韩志超

目录

更多学习资料请加添加作者微信:lockingfree获取

Selenium是一款浏览器自动化框架,Webdriver是其核心,同过Webdriver将自动化脚本转化为浏览器操作指令。
一般操作逻辑为:

  1. 打开网页
  2. 定位页面元素(链接,按钮,输入框等)
  3. 操作页面元素(点击,输入)
  4. 定位并操作下一个页面元素

Webdriver的工作原理

Webdriver会在本地启动一套WebService服务并绑定一个动态端口,脚本运行时通过selenium将请求发送到Webdriver服务端,然后经过不同的浏览器驱动,转换为浏览器指令。

浏览器基本操作

from selenium import webdriver
from time import sleep


browser = webdriver.Chrome()  # 打开Chrome
# browser = webdriver.Firefox()  # 打开Firefox
# browser = webdriver.Edge()  # 打开Edge
# browser = webdriver.Ie()  # 打开Ie

browser.get("http://www.baidu.com") # 打开网页
browser.maximize_window()  # 窗口最大化
print(browser.title)  # 当前页面的标题
print(browser.current_url)  # 当前url
print(browser.page_source)  # 网页源代码
sleep(1)
browser.get("http://115.28.108.130/control.html")
sleep(1)
browser.back()  # 后退
sleep(1)
browser.forward()  # 前进
browser.refresh()  # 刷新

sleep(3)
browser.quit()  # 退出

页面元素定位

8种基本定位方式

示例:

from selenium import webdriver
from time import sleep


browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")

browser.find_element_by_id("accountID").send_keys("hello")
browser.find_element_by_name("password").send_keys("123456")
browser.find_element_by_class_name("stuname").send_keys("class")

div = browser.find_element_by_tag_name("div") # 重复较多,只能定位到第一个,不推荐使用
print(div.get_attribute("id"))

# browser.find_element_by_link_text("百度首页走起~").click()
link = browser.find_element_by_link_text("百度首页走起~")
print(link.text)
link.click()
sleep(1)
browser.back()
browser.find_element_by_partial_link_text("百度首页").click()
browser.back()

label2 = browserb.find_element_by_xpath('/html/body/div[4]/label[2]')
print(label2.text)

summer = browser.find_element_by_xpath('//input[@id="u"][@value="summer"]')
summer.click()

browser.find_element_by_css_selector('#input > input').send_keys("1111")
browser.find_element_by_css_selector("#accountID").send_keys("张三")

补充:用By定位元素:

定位一组元素

当元素拥有相同的id/name/class_name/tag_name等时,可以定位到所有的元素,然后按顺序取得具体某个元素,这里使用find_elements_by_***,注意对一个s

from selenium import webdriver
from time import sleep


browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")

l = browser.find_elements_by_id("u")
for i in l:
    i.click()
l[2].click()

lables = browser.find_elements_by_tag_name("label")
print(lables[2].text)

分层定位

当一个元素不好定位时,可以先定位到容易定位的父级/祖先级元素,然后使用父级/祖先级元素继续定位,如:

from selenium import webdriver
from time import sleep


browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")
fardiv = browser.find_element_by_class_name("fathdiv")  # 先定位到父级元素
labels = fardiv.find_elements_by_tag_name("label")  # 使用父级元素向下定位
print(labels[2].text)

页面元素操作

示例:

from selenium import webdriver
from time import sleep


browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")
area = Select(browser.find_element_by_id("areaID"))
area.select_by_visible_text("上海")
sleep(1)
area.select_by_index(1)
sleep(1)
area.select_by_value("1")

此为北京龙腾育才 Python高级自动化(Selenium部分)授课笔记
课程介绍
想要参加现场(北京)/网络课程的可以联系作者微信:lockingfree

  1. 高效学习,快速掌握Python自动化所有领域技能
  2. 同步快速解决各种问题
  3. 配套实战项目练习
上一篇下一篇

猜你喜欢

热点阅读