Selenium WebDriver使用

简介: Selenium WebDriver使用

Selenium WebDriver使用

介绍

Selenium是一个浏览器自动化操作框架。selenium主要由三种工具组成。


第一个工具——SeleniumIDE,是Firefox的扩展插件,支持用户录制和回访测试。录制/回访模式存在局限性,对许多用户来说并不适合。

因此第二个工具——Selenium WebDriver提供了各种语言环境的API来支持更多控制权和编写符合标准软件开发实践的应用程序。

最后一个工具——SeleniumGrid帮助工程师使用Selenium API控制分布在一系列机器上的浏览器实例,支持并发运行更多测试。

在项目内部,它们分别被称为“IDE”、“WebDriver”和“Grid”。

回到顶部

webdriver

WebDriver 是一种用于 Web 应用程序的自动测试工具,提供了一套友好的 API,方便我们进行操作。


chromedriver下载安装

1、下载

chromedriver要与本地浏览器版本一致

下载地址(极客时间)

http://npm.taobao.org/mirrors/chromedriver/

2、使用

mac中将chromedriver解压后放在usr/local/bin下

windows将 Chrome 浏览器目录添加到系统的环境变量 Path中

或者在使用时直接指定chromedriver路径

chrome_driver = "C:\Users\cheny\AppData\Local\Google\Chrome\Application\chromedriver.exe"
driver = webdriver.Chrome(executable_path=chrome_driver)

3、测试

from selenium import webdriver
import time

wd = webdriver.Chrome()
wd.get("https://www.baidu.com")    # 打开百度浏览器
wd.find_element_by_id("kw").send_keys("selenium")   # 定位输入框并输入关键字
wd.find_element_by_id("su").click()   #点击[百度一下]搜索  
time.sleep(3)   #等待3秒
wd.quit()   #关闭浏览器
WebDriver常用操作
1、浏览器操作
from selenium import webdriver
driver = webdriver.Chrome()

#属性:
driver.current_url #用于获得当前页面的URL
driver.title #用于获取当前页面的标题
driver.page_source #用于获取页面html源代码
driver.port #用于获取浏览器的端口
driver.capabilities['version']  #打印浏览器version的值

#浏览器:
driver.get(url) #浏览器加载url
driver.back() #浏览器后退
driver.forward() #浏览器前进
driver.refresh() #浏览器刷新(点击刷新按钮)
driver.set_page_load_timeout(5) #设置页面加载时间,如果超时会跑异常
driver.implicitly_wait(秒) #隐式等待,通过一定的时长等待页面上某一元素加载完成。
#若提前定位到元素,则继续执行。等待10s若超过时间未加载出,则抛出NoSuchElementException异常。


#执行js:
driver.execute_script(js) #调用js

#互动到页面下方的两种方法(有的页面滑到底部会有加载更多)
js = "var q=document.documentElement.scrollTop=9000"    #1
js = "window.scrollTo(0,document.body.scrollHeight)"    #2
wd.execute_script(js)

2、窗口和弹框操作

#窗口:
driver.current_window_handle  #用于获取当前窗口句柄
driver.window_handles  #用于获取所有窗口句柄

driver.maximize_window()  #将浏览器最大化显示
driver.set_window_size(480, 800)  #设置浏览器宽480、高800显示
driver.get_window_size()  #获取当前窗口的长和宽
driver.get_window_position()  #获取当前窗口坐标
driver.set_window_position(300,200)  #设置当前窗口坐标
driver.get_screenshot_as_file(filename)  #截取当前窗口
#实例:driver.get_screenshot_as_file('D:/selenium/image/baidu.jpg')

driver.close()  #关闭当前窗口,或最后打开的窗口
driver.quit()  #关闭所有关联窗口,并且安全关闭session

#窗口切换:
driver.switch_to_frame(id或name属性值)#切换到新表单(同一窗口)。若无id或属性值,可先通过xpath定位到iframe,再将值传给switch_to_frame()
driver.switch_to.parent_content()#跳出当前一级表单。该方法默认对应于离它最近的switch_to.frame()方法
driver.switch_to.default_content() #跳回最外层的页面 
driver.switch_to_window(窗口句柄) #切换到新窗口 
driver.switch_to.window(窗口句柄) #切换到新窗口 

#弹框切换: 
driver.switch_to_alert() #警告框处理。处理JavaScript所生成的alert,confirm,prompt
driver.switch_to.alert() #警告框处理

3、cookies 操作

driver.get_cookies()   #获取当前会话所有cookie信息
driver.get_cookie(cookie_name)  #返回字典的key为“cookie_name”的cookie信息。
#实例:driver.get_cookie("NET_SessionId")

driver.add_cookie(cookie_dict)   #添加cookie。“cookie_dict”指字典对象,必须有name和value值
driver.delete_cookie(name,optionsString)  #删除cookie信息
driver.delete_all_cookies()  #删除所有cookie信息

4、简单对象的定位

'''
能通过id和name的,尽量不要用xpath和css
   Id定位
   唯一属性定位
   组合定位  
   先找到相邻的元素  
   绝对路径
'''

diver.find_element("xpath",".//a//span") #利于封装
 
driver.find_element_by_id()
driver.find_element_by_name()
driver.find_element_by_class_name()
driver.find_element_by_tag_name()
driver.find_element_by_link_text()
driver.find_element_by_partial_link_text()  #模糊查询
driver.find_element_by_xpath()
driver.find_element_by_css_selector()  #css选择定位器

5、页面元素操作

属性
element.size  #获取元素的尺寸。
element.text   #获取元素的文本。
element.tag_name   #获取标签名称

element.clear()  #用于清除输入框的默认内容
element.send_keys("xx")  #用于在一个输入框里输入 xx 内容
element.click()  #用于单击一个按钮
element.submit()  #提交表单
element.size  #返回元素的尺寸
element.text  #获取元素文本
element.get_attribute('value')
#返回元素的属性值,可以是id、name、type或元素拥有的其它任意属性
#如果是input的,可以通过获取value值获得当前输入的值

element.is_displayed ()
#返回元素的结果是否可见,返回结果为True或False

element.is_enabled()  #判断元素是否可用
element.is_selected()   #返回单选按钮、复选框元素结果是否被选中(True 或 False)
element.value_of_css_property(height)  #获取元素css样式属性

6、鼠标事件


引入ActionChains类 from selenium.webdriver.common.action_chains import ActionChains mouse =driver.find_element_by_xpath(“xx”) #定位鼠标元素 #对定位到的元素执行鼠标操作 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() #鼠标左键按下的操作 ActionChains(driver).release(mouse).perform() #鼠标释放 #鼠标拖拽 element = driver.find_element_by_name(“xxx”) #定位元素的原位置 target = driver.find_element_by_name(“xxx”) #定位元素要移动到的目标位置 ActionChains(driver).drag_and_drop(element, target).perform() #执行元素的移动操作


7、键盘事件

#引入Keys类包
from selenium.webdriver.common.keys import Keys

element.send_keys(Keys.BACK_SPACE)  #删除键(BackSpace)
element.send_keys(Keys.SPACE)  #空格键(Space)
element.send_keys(Keys.TAB)  #制表键(Tab)
element.send_keys(Keys.ESCAPE)  #回退键(Esc)
element.send_keys(Keys.ENTER)  #回车键(Enter)
element.send_keys(Keys.CONTROL,'a')  #全选(Ctrl+A)
element.send_keys(Keys.CONTROL,'c')  #复制(Ctrl+C)
element.send_keys(Keys.CONTROL,'x')  #剪切(Ctrl+X)
element.send_keys(Keys.CONTROL,'v')  #粘贴(Ctrl+V)
element.send_keys(Keys.F12)   #键盘F12

#输入空格键+“python”
element.send_keys(Keys.SPACE)
element.send_keys("python")

相关文章
|
4月前
|
数据采集 测试技术
Selenium与WebDriver:Errno 8 Exec格式错误的多种解决方案
本文讨论了在使用Selenium和WebDriver自动化测试时常见的执行格式错误(Errno 8 Exec format error)问题。错误通常发生在运行ChromeDriver时,与兼容性或路径配置有关。文章提供了多种解决方案,包括手动更改路径、更新或重新安装webdriver-manager包、下载特定版本的ChromeDriver、修改driver_cache.py文件。此外,还介绍了如何结合代理IP技术使用Selenium进行网页抓取,以提高效率和成功率。示例代码展示了如何配置代理IP并使用Selenium访问网站。通过这些方法,用户可以有效解决执行格式错误,并提高网页自动化测试
468 1
Selenium与WebDriver:Errno 8 Exec格式错误的多种解决方案
|
13天前
|
Web App开发 Java
使用java操作浏览器的工具selenium-java和webdriver下载地址
【10月更文挑战第12天】Selenium-java依赖包用于自动化Web测试,版本为3.141.59。ChromeDriver和EdgeDriver分别用于控制Chrome和Edge浏览器,需确保版本与浏览器匹配。示例代码展示了如何使用Selenium-java模拟登录CSDN,包括设置驱动路径、添加Cookies和获取页面源码。
|
5月前
|
前端开发 测试技术 UED
使用Selenium WebDriver模拟用户操作防止滑动条验证
在进行Web自动化测试时,经常会遇到各种前端验证机制,如滑动条验证,这些机制设计用来防止自动化脚本模拟用户行为。在本文中,我们将探讨如何使用Selenium WebDriver来模拟用户操作,以规避这些验证机制。
|
2月前
|
数据采集 Web App开发 测试技术
使用Selenium与WebDriver实现跨浏览器自动化数据抓取
在网络爬虫领域,Selenium与WebDriver是实现跨浏览器自动化数据抓取的利器。本文详细介绍了如何利用Selenium和WebDriver结合代理IP技术提升数据抓取的稳定性和效率。通过设置user-agent和cookie来模拟真实用户行为,避免被网站检测和阻止。文章提供了具体的代码示例,展示了如何配置代理IP、设置user-agent和cookie,并实现了跨浏览器的数据抓取。合理的参数配置能有效减少爬虫被封禁的风险,提高数据抓取效率。
257 6
使用Selenium与WebDriver实现跨浏览器自动化数据抓取
|
2月前
|
Web App开发 JavaScript Java
自动化测试的利剑:Selenium WebDriver入门与实践
【9月更文挑战第21天】在软件开发的海洋中,自动化测试犹如一艘船,帮助开发者们快速航行至质量保证的彼岸。本文将作为你的罗盘,指引你了解和掌握Selenium WebDriver这一强大的自动化测试工具。通过深入浅出的方式,我们将探索Selenium WebDriver的基本概念、安装过程以及编写简单测试脚本的方法。无论你是刚接触自动化测试的新手,还是希望提升测试技能的开发者,这篇文章都将为你提供有价值的指导。
|
2月前
|
Web App开发 Java 测试技术
自动化测试的利器:Selenium WebDriver入门与实践
【9月更文挑战第8天】在软件开发的海洋中,测试是确保我们不会溺水的那根救生索。Selenium WebDriver,作为自动化测试的明星工具,让这根救生索更加结实可靠。本文将带你快速上手Selenium WebDriver,从基础设置到实际操作,再到实战演练,让你的开发之旅更加平稳顺畅。
|
3月前
|
数据采集 Python
如何用Python Selenium和WebDriver抓取LinkedIn数据并保存登录状态
本文介绍了使用Python Selenium和WebDriver库抓取LinkedIn数据的方法。首先,安装Selenium库和对应的WebDriver,然后配置爬虫代理IP以避免频繁请求被检测。接下来,设置user-agent和cookies以模拟真实用户行为,实现登录并保持状态。登录后,使用WebDriver抓取目标页面数据,如用户名、年龄、性别和简历信息。最后,强调了优化代码、处理异常和遵守使用条款的重要性,以提高效率并避免账号被封禁。
如何用Python Selenium和WebDriver抓取LinkedIn数据并保存登录状态
|
3月前
|
JavaScript 测试技术 API
|
3月前
|
XML Java 测试技术
Selenium WebDriver自动化测试(基础篇):不得不掌握的Java基础
关于Selenium WebDriver自动化测试的Java基础篇,涵盖了Java的变量、数据类型、字符串操作、运算符、流程控制、面向对象编程、关键字用法、权限修饰符、异常处理和IO流等基础知识点,为进行自动化测试提供了必要的Java语言基础。
95 1
|
3月前
|
Web App开发 前端开发
Selenium WebDriver
【8月更文挑战第9天】
49 7