Selenium自动化案例

Posted wangdecheng

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Selenium自动化案例相关的知识,希望对你有一定的参考价值。

```
#!/usr/bin/env python

# -*- coding: utf-8 -*-

# @Time    : 2019/3/15 21:29

from seleniumimport webdriver

driver = webdriver.Chrome()# 可切换浏览器:Ie、Firefox

driver.maximize_window()# 浏览器窗口最大换

driver.implicitly_wait(8)# 设置隐式时间等待

driver.get("https://www.baidu.com")# 访问地址

driver.quit()# 关闭浏览器

# 完整的脚本例子-----------------------------

import time

from seleniumimport webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.implicitly_wait(5)

driver.get("https://www.baidu.com")

driver.find_element_by_xpath("//*[@id=‘kw‘]").send_keys("selenium")

# 搜索输入框输入Selenium.xpath定位、find_elements找的是一组元素,返回的是一个列表;

driver.find_element_by_xpath("//*[@id=‘su‘]").click()# 点击百度一下按钮

time.sleep(2)# 导入时间模块,等待2秒

# 断言1

# 这里通过元素XPath表达式来确定该元素显示在结果列表,从而判断Selenium官网这个链接显示在结果列表。# 这里采用了相对元素定位方法/../

# 通过selenium方法is_displayed() 来判断我们的目标元素是否在页面显示。driver.find_element_by_xpath("//div/h3/a[text()=‘官网‘]/../a/em[text()=‘Selenium‘]").is_displayed()

driver.quit()

# 上述例子可把断言1换成断言2

# 断言2

ele_string = driver.find_element_by_xpath("//div/h3/a[text()=‘官网‘]/../a").text

if (ele_string ==u"Selenium - Web Browser Automation"):

print "测试成功,结果和预期结果匹配!"

# 网页上获取自己想要的信息----------------

# 例如:获取到页面下的一些邮件信息

from seleniumimport webdriver

import re

driver = webdriver.Ie()

driver.maximize_window()

driver.implicitly_wait(5)

driver.get("http://home.baidu.com/contact.html")# 页面地址

doc = driver.page_source# 得到页面源代码

emails = re.findall(r[w][email protected][w.-]+, doc)# 利用正则,找出 [email protected] 的字段,保存到emails列表

for emailin emails:

print (email)

# 利用其他定位元素---------------------

from seleniumimport webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.implicitly_wait(6)

driver.get("https://www.baidu.com")

try:# try except语句块来进行测试断言,这个在实际自动化测试脚本开发中,经常要用到处理异常

    driver.find_element_by_id("kw")# 用ID方式定位百度输入框的元素位置,

# 还有其他一些定位方式

# tag name: driver.find_element_by_tag_name("form");

# link text: driver.find_element_by_link_text("新闻").凡是看到链接元素上面有文字描述的都可以采取find_element_by_link_text()方法来进行元素定位

# partial link text: driver.find_element_by_partial_link_text("主页").click()、

# class name : driver.find_element_by_class_name("s_ipt")  class name定位、

# name : driver.find_element_by_name("wd") name定位、

# css : driver.find_element_by_css_selector("#su") 、 找 ‘百度一下’ 这个按钮、css定位方式

    print (test pass: ID found)

except Exception as e:

print ("Exception found", format(e))

driver.quit()

# 清空输入文本----------------------

driver.find_element_by_id("kw").clear()

# 刷新页面方法---------------------

driver.refresh()

# 浏览器中的前进、后退操作-------------------

# driver.back()

# driver.forward()

import time

from seleniumimport webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.implicitly_wait(6)

driver.get("https://www.baidu.com")

time.sleep(2)

elem_news = driver.find_element_by_link_text("新闻")

elem_news.click()# 点击进入到百度新闻time.sleep(2)

driver.back()# 从百度新闻后退到百度首页time.sleep(2)

driver.forward()# 百度首页前进到百度新闻time.sleep(2)

driver.quit()

# 获取浏览器版本----------------------------------

print (driver.capabilities[version])

# current_url 方法可以得到当前页面的URL----------

print (driver.current_url)

# title方法可以获取当前页面的标题显示的字段-------

print (driver.title)

# 浏览器中重新开一个tab,利用键盘快捷键(ctrl+t)-----------------

ele = driver.find_element_by_tag_name(body).send_keys(Keys.CONTROL +t)

#

import time

from seleniumimport webdriver

from selenium.webdriver.common.keysimport Keys

driver = webdriver.Firefox()

driver.maximize_window()

driver.implicitly_wait(6)

driver.get("http://www.baidu.com/")

time.sleep(1)

ele = driver.find_element_by_tag_name(body).send_keys(Keys.CONTROL +t# 触发ctrl + t

time.sleep(1)

# 点击单选框-----------------------------

for iin driver.find_elements_by_xpath("//*/input[@type=‘radio‘]"):

i.click()

#

from seleniumimport webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get(http://news.baidu.com)

driver.implicitly_wait(8)

for iin driver.find_elements_by_xpath("//*/input[@type=‘radio‘]"):

i.click()

# 点击复选框-----------------------------

import time

from seleniumimport webdriver

driver = webdriver.Ie()

driver.maximize_window()

driver.get(https://www.baidu.com)

driver.implicitly_wait(8)

driver.find_element_by_xpath("//*[@id=‘u1‘]/a[7]").click()

time.sleep(1)

driver.find_element_by_xpath("//*[@id=‘TANGRAM__PSP_10__footerULoginBtn‘]").click()

time.sleep(1)

driver.find_element_by_xpath("//*[@id=‘TANGRAM__PSP_10__memberPass‘]").click()

# 设置屏幕分辨率-----------------------------------

driver.set_window_size(1024, 768)

driver.set_window_size(1280, 800)

#

import time

from seleniumimport webdriver

driver = webdriver.Chrome()

driver.maximize_window()# 全屏driver.get(‘https://www.baidu.com‘)

time.sleep(1)

print (driver.get_window_size())

driver.set_window_size(1280, 800)# 分辨率1280*800

time.sleep(1)

print (driver.get_window_size())

driver.set_window_size(1024, 768)# 分辨率1024*768

time.sleep(1)

print (driver.get_window_size())

# title断言--------------------------------------------------

import time

from seleniumimport webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get(https://www.baidu.com)

time.sleep(1)

# 方法一try:

assert u"百度一下" in driver.title

print (Assertion test pass.)

except Exception as e:

print (Assertion test fail., format(e))

# 方法二if u"百度一下,你就知道" == driver.title:

print (Assertion test pass.)

else:

print (Assertion test fail.)

print driver.title

# 获取错误信息进行对比、匹配------------------------------

import time

from seleniumimport webdriver

from selenium.webdriver.common.keysimport Keys

driver = webdriver.Firefox()

driver.maximize_window()

driver.implicitly_wait(6)

driver.get("http://www.baidu.com/")

time.sleep(1)

driver.find_element_by_xpath("//*[@id=‘u1‘]/a[7]").click()

time.sleep(1)

driver.find_element_by_xpath("//*[@id=‘TANGRAM__PSP_8__submit‘]").click()

# 断言方法一try:

error_message = driver.find_element_by_xpath(

"//*[@id=‘TANGRAM__PSP_8__error‘ and text()=‘请您填写手机/邮箱/用户名‘]").is_displayed()

print ("Test pass. the error message is display.")

except Exception as e:

print ("Test fail.", format(e))

# 断言方法二,本文重点介绍方法error_mes = driver.find_element_by_xpath("//*[@id=‘TANGRAM__PSP_8__error‘]").text

try:

assert error_mes ==u请您填写手机/邮箱/用户名

print (Test pass.)

except Exception as e:

print ("Test fail.", format(e))

# 断言验证某个按钮是否被选中

from seleniumimport webdriver

import time

driver = webdriver.Ie()

driver.maximize_window()

driver.implicitly_wait(5)

driver.get("http://news.baidu.com/")

time.sleep(2)

# 验证元素大小是否符合需求设计---------------

import time

from seleniumimport webdriver

driver = webdriver.Firefox()

driver.maximize_window()

driver.implicitly_wait(6)

driver.get("https://www.baidu.com/")

time.sleep(1)

search_btn = driver.find_element_by_id(su)

print (search_btn.size)

# 页面文本全选操作ctrl+a------------------------

import time

from seleniumimport webdriver

from selenium.webdriver.common.keysimport Keys

driver = webdriver.Chrome()

driver.maximize_window()

driver.get(https://www.baidu.com)

element = driver.find_element_by_tag_name(body)

element.send_keys(Keys.CONTROL +a)

# 退格键删除信息操作-------------------------

import time

from seleniumimport webdriver

from selenium.webdriver.common.keysimport Keys

driver = webdriver.Chrome()

driver.maximize_window()

driver.get(https://www.baidu.com)

element = driver.find_element_by_id(kw)

element.send_keys("Selenium automation")

time.sleep(1)

element.send_keys(Keys.CONTROL +a)

element.send_keys(Keys.BACKSPACE)

# 鼠标右键操作,如:右键点开按钮,选择选项-----------------------

import time

from seleniumimport webdriver

from selenium.webdriverimport ActionChains

from selenium.webdriver.common.keysimport Keys

driver = webdriver.Chrome()

driver.maximize_window()

driver.get(https://www.baidu.com)

time.sleep(2)

element = driver.find_element_by_xpath("//*[@id=‘lg‘]/img")

actionChains = ActionChains(driver)

actionChains.context_click(element).send_keys(Keys.ARROW_DOWN).send_keys(Keys.ENTER).perform()

actionChains.context_click(element).send_keys(i).perform()

# 如何执行js脚本-----------------------------------

# 实例一 执行js脚本触发一个alert弹出框

import time

from seleniumimport webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.implicitly_wait(6)

driver.get("https://www.baidu.com")

time.sleep(1)

driver.execute_script("window.alert(‘这是一个alert弹框。‘);")# 注意这里的分号是英文输入法的分号,不能用中文

# 实例二 执行js脚本来控制浏览器竖向滚动条

# 打开百度贴吧,然后拖动滚动条到左侧 “地区”

# coding=utf-8

import time

from seleniumimport webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.implicitly_wait(6)

driver.get("https://tieba.baidu.com/index.html")

time.sleep(1)

target_elem = driver.find_element_by_link_text("地区")

driver.execute_script("return arguments[0].scrollIntoView();", target_elem)# 用目标元素参考去拖动

driver.execute_script("scroll(0,2400)")# 这个是第二种方法,比较粗劣,大概的拖动

# 获取页面包含href元素的超链接,爬虫中常用-----------------

import time

from seleniumimport webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.implicitly_wait(6)

driver.get("https://www.baidu.com")

time.sleep(1)

for linkin driver.find_elements_by_xpath("//*[@href]"):

print (link.get_attribute(href))

driver.quit()

# 截图保存操作,测试脚本中有异常报错时可用的该方法--------------------------

import time

from seleniumimport webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.implicitly_wait(6)

driver.get("https://www.baidu.com")

time.sleep(1)

driver.get_screenshot_as_file("C:\Users\你的账户名\Desktop\baidu.png")

driver.quit()

 

以上是关于Selenium自动化案例的主要内容,如果未能解决你的问题,请参考以下文章

Selenium2+python自动化10-登录案例

Selenium Xpath元素无法定位 NoSuchElementException: Message: no such element: Unable to locate element(代码片段

Selenium自动化案例

web自动化10-selenium登录案例

selenium综合案例

Python3+Selenium Web自动化测试案例分享⑹——unittest组织测试用例