草庐IT

UI自动化测试之八大元素定位方法(最新版)

软测小子 2024-05-14 原文

Selenium—UI自动化测试之八大元素定位方法(最新版)

前言

UI界面本质上就是HTML直接体现,脚本通过HTML标签信息来找到具体的元素。
元素定位:通过代码调用方法查找元素

一、ID定位

  • 概念:通过元素的id属性来定位元素
  • 前置:所要定位的元素必须要有id属性
  • 方法:driver.find_element(By.ID,“”)
    **示例:**输入用户名和密码
import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 1.获取浏览器(创建浏览器驱动对象)
driver = webdriver.Chrome()
# 2.输入url,打开web页面
driver.get("http://hmshop-test.itheima.net/home/User/login.html")
# 3.查找操作元素
# 用户名
driver.find_element(By.ID, "username").send_keys("111111")
# 密码
driver.find_element(By.ID, "password").send_keys("000000000")
time.sleep(3)
# 4.关闭浏览器驱动对象
driver.quit()

二、name定位

  • ⽅法:driver.find_element(By.NAME,“name属性值”)
  • 前置: 标签必须有name属性
  • 特点: 当前⻚⾯可以重复
  • 提示: 由于name属性值可以重复,所以使⽤时需要查看是否为唯⼀

示例

import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 1.获取浏览器(创建浏览器驱动对象)
driver = webdriver.Chrome()
# 2.输入url,打开web页面
driver.get("http://hmshop-test.itheima.net/home/User/login.html")
# 3.查找操作元素
# 用户名
driver.find_element(By.NAME, "username").send_keys("111111")
# 密码
driver.find_element(By.NAME, "password").send_keys("000000000")
time.sleep(3)
# 4.关闭浏览器驱动对象
driver.quit()

三、class定位

  • ⽅法:driver.find_element(By.CLASS_NAME,“class属性值”)
  • 前置: 标签必须有class属性
  • 特点: class属性可以有多个值。
  • 提示:如果标签有多个class值,只能任意选择其中一个,如下图driver.find_element(By.CLASS_NAME,“c1”)

示例

import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 1.获取浏览器(创建浏览器驱动对象)
driver = webdriver.Chrome()
# 2.输入url,打开web页面
driver.get("http://hmshop-test.itheima.net/home/User/login.html")
# 3.查找操作元素
# 用户名
driver.find_element(By.CLASS_NAME, "text_cmu").send_keys("111111")
time.sleep(3)
# 4.关闭浏览器驱动对象
driver.quit()

四、Tag_name定位

  • 说明:根据的标签名进⾏定位
  • ⽅法:driver.find_element(By.TAG_NAME,“标签名”)
  • 提示:如果⻚⾯存在多个相同标签,默认返回第⼀个。
import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 1.获取浏览器(创建浏览器驱动对象)
driver = webdriver.Chrome()
# 2.输入url,打开web页面
driver.get("http://hmshop-test.itheima.net/home/User/login.html")
# 3.查找操作元素
# 用户名
driver.find_element(By.TAG_NAME, "input").send_keys("111111")
time.sleep(3)
# 4.关闭浏览器驱动对象
driver.quit()

五、link_text定位

  • 说明:根据链接文本(a标签)定位
  • 方法:driver.find_element(By.LINK_TEXT,“链接文本”)
  • 特点:传入的链接文本,必须全部匹配,不能模糊。
import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 1.获取浏览器(创建浏览器驱动对象)
driver = webdriver.Chrome()
# 2.输入url,打开web页面
driver.get("http://hmshop-test.itheima.net/home/User/login.html")
# 3.点击超链接
driver.find_element(By.LINK_TEXT, "忘记密码?").click()
time.sleep(3)
# 4.关闭浏览器驱动对象
driver.quit()

六、partial_link_text定位

  • 说明:根据链接(a标签)文本定位
  • 方法:driver.find_element(By.PARTIAL_LINK_TEXT,“链接文本”)
  • 特点:传入的链接文本,支持模糊匹配。
import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 1.获取浏览器(创建浏览器驱动对象)
driver = webdriver.Chrome()
# 2.输入url,打开web页面
driver.get("http://hmshop-test.itheima.net/home/User/login.html")
# 3.点击超链接
driver.find_element(By.PARTIAL_LINK_TEXT, "忘").click()
time.sleep(3)
# 4.关闭浏览器驱动对象
driver.quit()

扩展-查找一组元素

  • 说明:返回列表格式,要使用需要列表下标(索引)或遍历.
  • 方法:driver.find_elements(By.TAG_NAME, “input”)
  • 特点:⼋⼤元素定位⽅法,都可以使⽤⼀组元素定位,如果没有搜索到符合标签,返回空
    列表。
import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 1.获取浏览器(创建浏览器驱动对象)
driver = webdriver.Chrome()
# 2.输入url,打开web页面
driver.get("http://hmshop-test.itheima.net/home/User/login.html")
# 3.查找操作元素
# 查找所有的input标签
inputs = driver.find_elements(By.TAG_NAME, "input")
inputs[0].send_keys("11111")
inputs[1].send_keys("11111")
inputs[2].send_keys("11114")
time.sleep(3)
# 4.关闭浏览器驱动对象
driver.quit()

七、xpath定位

为什么要学习xpath,css
1.如果标签没有(id,name,class)3个属性,也不是链接标签,只能使用Tag_name定位,比较麻烦
2.方便在工作中查找元素,使用xpath和css比较方便(支持任意属性,层级)来找元素
什么是xpath?
说明:XPATH是xml path的简称,使用标签路径来定位

  1. 路径: - 绝对路径:/…/…/ 从根目录开始,逐级查找标签。
    - 相对路径://…//…从任意层级开始,查找标签。
    - 方法:driver.find_element(By.XPATH, “xpath表达式”)
  2. 属性:单属性://*[@属性名=’属性值’]
  3. 属性与逻辑(多个属性):多属性://*[@属性名=’属性值’ and @属性名=’属性值’] 提示:可以使用任何属性。
  4. .属性与层级:说明:如果元素现有的属性不能唯一匹配,需要结合层级使用
    //语法://父标签[@属性=‘值’]/子标签 :必须为直属后代子级。//父标签//后代标签:父标签和后代之间可以跨越元素

5.扩展:

  • 根据显示文本定位://*[text()=‘文本值’] 文本值必须全部匹配
  • 属性值模糊匹配://*[contains(@属性名,‘属性部分值’)]
import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 1.获取浏览器(创建浏览器驱动对象)
driver = webdriver.Chrome()
# 2.输入url,打开web页面
driver.get("http://hmshop-test.itheima.net/home/User/login.html")
# 3.查找操作元素
# 使用绝对路径输入用户名
driver.find_element(By.XPATH, "/html/body/div[2]/div/div[2]/div/form/div/div[1]/input").send_keys(1111)
time.sleep(2)
# 使用相对路径输入用户名
# driver.find_element(By.XPATH, "//div[2]//input").send_keys(2222)
# 使用xpath属性输入用户名(单属性)
# driver.find_element(By.XPATH, "//*[@id='username']").send_keys(2222)
# 属性与逻辑/多属性(and)
# driver.find_element(By.XPATH, "//*[@name='username' and @id='username']").send_keys(2222)
# 属性与层级
# driver.find_element(By.XPATH, "//div[@class='text_uspa']/input").send_keys(2222)
# 扩展 关键字:包含 contains
# driver.find_element(By.XPATH, "//input[contains(@placeholder,'手机')]").send_keys(2222)
# 扩展 根据链接文本
driver.find_element(By.XPATH, "//*[text()='忘记密码?']").click()

time.sleep(3)
# 4.关闭浏览器驱动对象
driver.quit()

八、css定位

  • 说明:css选择器是html查找元素的工具。
  • 策略:
  		id选择器:#id属性值
  		类选择器:.class属性值
  		标签选择器:标签名  (注意标签名是否在页面中唯一,否则返回单个或所有)
  		属性选择器:[属性名='属性值'] (标签任意属性都可以)
  		层级选择器:父子关系:选择器>选择器  后代关系:选择器 选择器。(选择器使用任何一种css选择器都可以)

总结

结论:

  • 首推css选择器定位。原因:执行速度快。如果有ID属性,使用#id。如果没有id属性,使用其他有的属性(能代表唯一的属性),如果属性都代表不了唯一,使用层级。
  • 如果css解决不了,使用xpath。

有关UI自动化测试之八大元素定位方法(最新版)的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

    很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

  5. ruby - i18n Assets 管理/翻译 UI - 2

    我正在使用i18n从头开始​​构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在ruby​​onrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi

  6. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  7. Ruby 方法() 方法 - 2

    我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby​​-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco

  8. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

  9. ruby - 使用 C 扩展开发 ruby​​gem 时,如何使用 Rspec 在本地进行测试? - 2

    我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当

  10. ruby - Highline 询问方法不会使用同一行 - 2

    设置:狂欢ruby1.9.2高线(1.6.13)描述:我已经相当习惯在其他一些项目中使用highline,但已经有几个月没有使用它了。现在,在Ruby1.9.2上全新安装时,它似乎不允许在同一行回答提示。所以以前我会看到类似的东西:require"highline/import"ask"Whatisyourfavoritecolor?"并得到:Whatisyourfavoritecolor?|现在我看到类似的东西:Whatisyourfavoritecolor?|竖线(|)符号是我的终端光标。知道为什么会发生这种变化吗? 最佳答案

随机推荐