2019-03-15 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]+@[\w\.-]+', doc)# 利用正则,找出 xxx@xxx.xxx 的字段,保存到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()

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容