知否知否-----selenium知多少

简介: 知否知否-----selenium知多少

关于selenium,就不多介绍什么了,主要就是用来进行自动化的工具。怎样进行自动化,这才是它大放异彩的地方。下面就来看看吧!

640.jpg


selenium定位


关于定位,一共有八种方法:

  • find_element_by_id()
  • find_element_by_name()
  • find_element_by_class_name()
  • find_element_by_tag_name()
  • find_element_by_link_text()
  • find_element_by_partial_link_text()
  • find_element_by_xpath()
  • find_element_by_css_selector()


用的比较多的是id,xpath


xpath的话不一定需要xpath基础,主要是chrome浏览器可以在控制卡右键获取,是不是很方便??


还有一些其他的:


下面是我们要定位的元素(从百度[www.baidu.com]拿过来的):

<input id="kw" class="s_ipt" name="wd" 
value="" maxlength="255" autocomplete="off"


  • 通过id定位:
dr.find_element_by_id("kw")
  • 通过name定位:
dr.find_element_by_name("wd")
  • 通过class name定位:
dr.find_element_by_class_name("s_ipt")
  • 通过tag name定位:
dr.find_element_by_tag_name("input")
  • 通过css定位:
dr.find_element_by_css_selector("#kw")



Selenium控制浏览器

首先,最基础的,打开百度:

from selenium import webdriver
driver = webdriver.Chrome()
driver.get("http://www.baidu.com")

这个应该没多大问题。


关于浏览器的一些设置这才是重点:

现在我需要:

设置浏览器宽400、高900显示

driver.set_window_size(400, 900)

driver.set_window_size(400, 900)


控制浏览器前进、后退:

我们打开了第二个网页新闻

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

后退到一开始的百度:

driver.back()

再前进到新闻

driver.forward()



Selenium-Webdriver常用方法


用户对于网页的常用操作无非以下几种:


点击

driver.find_element_by_id("kw").click()

在找到元素后触发点击事件


输入:

driver.find_element_by_id("kw").send_keys("python大法好")

找到输入框后,触发输入方法


(这里有一点要说一下,为了证明你是一个合格的或者是比较细心的tester,这时候你就需要在输入之前做一件事,这件事就是清空数据,防止输入框里面有缓存数据,我们就需要清空

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


还有就是表单提交

driver.find_element_by_id("kw").send_keys("python大法好").submit()

submit方法


还有一些不常用的方法:

获取元素的大小尺寸:

driver.find_element_by_id("kw").size


获取元素的文本:

driver.find_element_by_id("kw").text


获取属性值:

driver.find_element_by_id("kw").get_attribute('type')


查看元素是否可见:

driver.find_element_by_id("kw").is_displayed()






Selenium鼠标


关于鼠标,我们之前有个click事件其实就说鼠标的功能,现在我们看看还有哪些常用操作。


在selenium里,这些操作都封装在ActionChains 类中。

可以通过下面这种方法直接导入ActionChains这个类:

from selenium.webdriver import ActionChains
  • perform(): 执行所有 ActionChains 中存储的行为;
  • context_click(): 右击;
driver.find_element_by_id("kw").context_click()
  • double_click(): 双击;
driver.find_element_by_id("kw").double_click()
  • drag_and_drop(): 拖动;
  • move_to_element(): 鼠标悬停。


鼠标悬停的时候分为两步,先定位到悬停的元素,再对定位到的元素执行鼠标悬停操作。

above = driver.find_element_by_link_text("设置")
ActionChains(driver).move_to_element(above).perform()



Selenium键盘事件


Keys()类提供了键盘上几乎所有按键的方法。


我们之前说过send_keys()方法可以用来模拟键盘输入。


删除一个字符

如果说之前输入了1233

driver.find_element_by_id("kw").send_keys(Keys.BACK_SPACE)

执行了这一句之后输入就变成123


输入空格

driver.find_element_by_id("kw").send_keys(Keys.SPACE)


全选输入框的内容 Ctrl + a

driver.find_element_by_id("kw").send_keys(Keys.CONTROL, 'a')


剪贴  Ctrl + x

driver.find_element_by_id("kw").send_keys(Keys.CONTROL, 'x')


粘贴 Ctrl + v

driver.find_element_by_id("kw").send_keys(Keys.CONTROL, 'v')


复制 Ctrl + c

driver.find_element_by_id("kw").send_keys(Keys.CONTROL, 'c')

回车键

driver.find_element_by_id("su").send_keys(Keys.ENTER)




Selenium断言


做测试最重要的就是断言,我们通常可以通过获取title 、URL和text等信息进行断言。

在python里面有个assert的关键字,这是我们做断言的关键,在selenium里面我们可以将测试的结果和预期的结果做比较,这样就是一种断言。


driver.title
driver.find_element_by_class_name('nums').text



Selenium等待

9

等待分为两种,一种是显式等待,一种是隐式等待。

显式等待是WebdDriver等待某个条件成立时继续执行,否则在达到最大时长时抛出超时异常。


WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)
driver :浏览器驱动。
timeout :最长超时时间,默认以秒为单位。
poll_frequency :检测的间隔(步长)时间,默认为0.5S。
ignored_exceptions :超时后的异常信息,
默认情况下抛NoSuchElementException异常。
WebDriverWait()一般由until()或until_not()方法配合使用,
下面是until()和until_not()方法的说明。
until(method, message=‘’)
调用该方法提供的驱动程序作为一个参数,直到返回值为True。
until_not(method, message=‘’)
调用该方法提供的驱动程序作为一个参数,直到返回值为False。


driver = webdriver.Chrome()
driver.get("http://www.baidu.com")
element = WebDriverWait(driver, 5, 0.5).until(
                      EC.presence_of_element_located((By.ID, "kw")))
element.send_keys('python乱炖')



隐式等待

WebDriver提供了implicitly_wait()方法来实现隐式等待,默认设置为0。它的用法相对来说要简单得多。


driver.implicitly_wait(1)


这就是一个简单的隐式等待。

默认参数的单位为秒,本例中设置等待时长为1秒。首先这1秒并非一个固定的等待时间,它并不影响脚本的执行速度。其次,它并不针对页面上的某一元素进行等待。当脚本执行到某个元素定位时,如果元素可以定位,则继续执行;如果元素定位不到,则它将以轮询的方式不断地判断元素是否被定位到。若直到超出设置时长(1秒)还没有定位到元素,则抛出异常。



下期继续。


相关文章
|
9月前
|
JavaScript 前端开发 测试技术
知否知否-----selenium知多少(二)
知否知否-----selenium知多少(二)
72 0
|
2月前
|
JavaScript 前端开发 测试技术
Python Selenium基本用法
Python Selenium基本用法
36 2
|
3月前
|
Web App开发 数据采集 前端开发
基于Python的Selenium详解:从入门到实践
基于Python的Selenium详解:从入门到实践
121 0
|
4月前
|
Web App开发 Python
Python使用selenium的Chrome下载文件报错解决
Python使用selenium的Chrome下载文件报错解决
58 0
|
4月前
|
Web App开发 Python
python+selenium+Chrome 监测文件是否下载完毕
python+selenium+Chrome 监测文件是否下载完毕
74 0
|
22天前
|
前端开发 测试技术 C++
Python自动化测试面试:unittest、pytest与Selenium详解
【4月更文挑战第19天】本文聚焦Python自动化测试面试,重点讨论unittest、pytest和Selenium三大框架。unittest涉及断言、TestSuite和覆盖率报告;易错点包括测试代码冗余和异常处理。pytest涵盖fixtures、参数化测试和插件系统,要注意避免过度依赖unittest特性。Selenium的核心是WebDriver操作、等待策略和测试报告生成,强调智能等待和元素定位策略。掌握这些关键点将有助于提升面试表现。
27 0
|
1月前
|
Web App开发 测试技术 网络安全
|
2月前
|
Web App开发 前端开发 JavaScript
Python Selenium是一个强大的自动化测试工具
Python Selenium是一个强大的自动化测试工具
|
2月前
|
Web App开发 测试技术 Python
使用 Python 结合 Selenium 访问一个 url
使用 Python 结合 Selenium 访问一个 url
29 0
|
2月前
|
Web App开发 安全 定位技术
关于使用 Python 和 Selenium chrome driver 访问 url 时修改 source ip 的问题
关于使用 Python 和 Selenium chrome driver 访问 url 时修改 source ip 的问题
60 0