首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

WebDriver nth -- 完美结合css和xpath的优点而来 附,常见元素定位方式总结

猜想下去你的脚本可能是从头到尾xpath, 第一个元素便开始定位着每个元素的绝对路径, 还有些同行, 至今仍使用Selenium IDE 导出脚本,当然这也是可以的~    我们先说第一种的弊端: 首先作为一个测试来说...so anyway , 言归正传:我们在写脚本的时候,要懂得去规划和构思, 一个元素的位置千变万化, 位置可能变,属性是不可能一变万变的, so,在我们的日常测试中一定要秉承, 代码最大程度可用性, 元素定位优先稳定...id /name /calss/css/xpath......还有很多就不一一列举,  这么多种方式都可以定位到这个元素, 那我们在定位的时候就要去考虑怎么样最大限度的采用稳定性最高的定位方式使用在脚本中, 找到元素最不容易改变的属性拿来定位, 在脚本中尽量多用方法...下面跟大家分享一种笔者自己很喜欢的定位方式 : 笔者最喜欢的就是 css, 然后就是它,哈哈哈    伪类元素定位法, but anyway, 现在你去找是很难找到这种定位方式要怎么具体使用的,先定义两个变量

54230

selenium webdriver——设置元素等待

如今大多数Web应用程序使用ajax技术,当浏览器在加载页面时,页面上的元素可能并不是同时被加载完成,这给定位元素的定位增加了困难, 如果因为在加载某个元素时延迟而造成ElementNotVisibleException...(不可见元素异常)的情况出现,那么就会降低自动化脚本的稳定性,设置元素等待可改善这种问题造成的不稳定。...WebDriver提供了两种类型的等待: 显示等待: 具体格式如下: from selenium import webdriver from selenium.webdriver.common.by import...is_displayed() 该元素是否用户可以见 move_to_element(menu) 移动鼠标到一个元素中,menu上面已经定义了他所指向的哪一个元素 to_element...:元件移动到 perform() 执行所有存储的行为 隐式等待: 通过一定的时长等待页面上某元素加载完成,如果超出了设置的时长元素还没有被加载,则抛出NoSuchElementException

1.3K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    在Selenium Webdriver中使用XPath Contains、Sibling函数定位

    前言 在一般情况下,我们通过简单的xpath即可定位到目标元素,但对于一些既没id又没name,而且其他属性都是动态的情况就很难通过简单的方式进行定位了。...在这种情况下,我们需要使用xpath1.0内置的函数来进行定位,下面我们重点讨论一下3个函数: Contains Sibling Contains函数 通过contains函数,我们可以提取匹配特定文本的所有元素...例如在百度首页,我们使用contains定位包含“新闻”文本的元素。...("//div/a[contains(text(), 新闻)]") sibling函数 通过sibling函数我们可以提取指定元素的所有同级元素,即获取目标元素的所有兄弟节点。...# 定位 通过contains 定位包含“新闻”的元素 new_node = driver.find_element_by_xpath( u"//div/a[contains(text(

    2.2K30

    Selenium WebDriver找不到元素的三种情况

    今天抽点时间总结下Selenium WebDriver找不到元素的情况。 当然这里说的是css或者XPath都没写错,定位准确,也并非使用了不稳定的定位语句。...# -*- coding: utf-8 -*- from selenium import webdriver driver = webdriver.Chrome() driver.get('https:...解决: 只要刷新页面之后重新获取元素就行,不要提前获取一组元素,然后去循环操作每一个元素,这种情况还是获取元素的个数,然后在循环中获取相应位置的元素,在用的时候才去获取,这样你就获取到最新的id了,也不会出现找错人的尴尬了...我就使用了一个循环,但是最开始没细看,直接循环成了元素,到新页面验证完成之后又返回原来的页面继续定位,发现定位不了了;这时我才想起来不应该循环元素,应该循环元素的个数,在这个循环的过程中再来定位获取元素...Python:time.sleep(10) Java:Thread.sleep(1000);//单位是毫秒,1000毫秒=1秒 添加智能等待,隐式的等待一个元素被发现或一个命令完成 webdriver

    5.3K50

    如何在Selenium WebDriver中查找元素?(一)

    在Selenium WebDriver中查找元素:“ FindElement”和“ FindElements”之间的区别 查找元素 查找元素 如果定位器发现了多个Web元素,则返回第一个匹配的Web元素...有多种方法可以唯一地标识网页中的一个Web元素,例如ID,名称,类名,链接文本,部分链接文本,标记名和XPATH。...Text/Partial Link Text CSS Selector XPATH Selector 现在让我们尝试看看如何使用这些策略中的每一个来查找元素或元素。...如果任何网站具有非唯一ID或具有动态生成的ID,则不能使用此策略唯一地查找元素,而是将返回与定位器匹配的第一个Web元素。我们将如何克服这种情况,将在XPATH / CSS选择器策略中进行说明。...但是,CSS选择器虽然具有更简单的语法支持,但不像XPATH和其他文档支持那样是标准的,与XPATH不同。

    6.1K10

    五、XPath实战:快速定位网页元素

    分析网站本节我们来爬取豆瓣电影,在实战开始前,我们需要搞懂爬取的流程,在清楚爬取的步骤后,我们方可事半功倍导入需要的库分析获取网站URL获取HTML页面etree解析使用Xpath插件进行测试标签编写Xpath...start={}'.format(i) urls.append(url)获取每页URL中的影评URL接下来我们需要获取每页中影评的具体URL右击鼠标点击检查,我们就会看到具体的URL,为了测试Xpath...提取每个电影影评的url detail_url = html.xpath('//h2/a/@href') detail_urls.append(detail_url)获取电影影评数据做完先前的工作...,这里可以说是核心的步骤了,获取真正有用的数据获取电影名title = html.xpath('//div[@class="subject-title"]/a/text()')[0][2:]这里会有人好奇为什么后面需要切一下...,原因如下,前面有一些无用的数据,需要清除获取评论者和评分commenter = html.xpath('//header/a/span/text()')[0]rank = html.xpath('//

    30380

    xpath定位随机元素之starts-with的用法

    相信有一部分朋友在做UI自动化的时候,会遇到有些元素,明明这次定位到之后,到时重新进入页面,里面的元素值就变样了。...下面我们来看看如何定位随机生成的元素~~ starts-with 如图,这个是我们公司的项目,在处理一个勾选框的时候,里面的id元素是随机生成的,我们可以使用xapth中提供的starts-with方法...,首先定位到 li 这个标签下,然后找到id的元素,可以看到id后面的那串数字都是随机生成的,每次进入页面都不一样,但是我发现前面的“cascader-menu”内容是固定的,因此我们可以使用starts-with...找元素内容从“cascader-menu”开始的元素 ends-with xpath中也提供了ends-with的方法,使用方法跟starts-with相同,它是以某字符串结尾的元素。...conatins //div[1]/div/div[3]//li[contains(@id, "cascader-menu")] [1] 使用xpath中的contains方法,也是可以的~大家可以根据需要结合使用

    1.9K10

    selenium-webdriver|3 API之元素定位

    () 当没有id属性,如果有name属性,使用name进行定位 driver.findElement(By.name("btnName")) By.className() className属性是利用元素的...css样式进行元素查找的方法 driver.findElement(By.className("btn-submit")); By.tagName() 这个方法搜索到的元素通 常不止一个,所以一般使用findElements...() cssSelector这种元素定位方式跟xpath比较类似,同时如果需要指定多个属性值或定位使用了复合样式表的元素可以使用cssSelector定位 多个属性值组合定位 driver.findElement...("button.btn.btn-submit.btn-primary")) By.xpath() 这个方法是非常强大的元素查找方式,使用这种方法几乎可以定位到页面上的任意元素 driver.findElement...(By.xpath("//*div/button [@id='submit']")) 层级定位方式介绍 先定位到父级元素 再定位子元素 <li class

    1.6K10

    如何在Selenium WebDriver中查找元素?(二)

    最近,我在努力寻找定位Web元素的方法。在各种环境中使用相同版本的SaaS实例会生成不同的Ids.XPATH选择器助我一臂之力,我主要使用contains()选项来定位Web元素。...下面简要说明这些内容 绝对和相对XPath 绝对 相对的 定位元素的直接方法 从DOM元素的中间开始 如果访问元素的路径因位置而改变,则脆性可能会破裂 由于搜索相对于DOM相对稳定 以“ /”开头并从根开始...公共类LocateByXPATHSel { 公共静态void主(字符串[] args){ WebDriver驱动程序=新的FirefoxDriver(); // Chrome的实例| Firefox...要在以下情况下获取所有'li'元素,我们将语法编写为 –//ul[@id ='_ FOpt1:_FOr1:0:_FOSritemNode_workforce_management_new_person:...语法: // tagName [@ attribute = value] //之前:: tagName 在Selenium WebDriver中查找元素:在元素数组中查找元素 ?

    2.9K20

    《前端5分钟》之使用解释器模式实现获取元素Xpath路径的算法

    前端领域里基于javascript的设计模式和算法有很多,在很多复杂应用中也扮演着很重要的角色,接下来就介绍一下javascript设计模式中的解释器模式,并用它来实现一个获取元素Xpath路径的算法。...这里我们只考虑html,即元素在html页面中所处的路径。 那么如何快速获取元素的Xpath路径呢?其实也很简单,我们打开谷歌调试工具: ? ? 选中Copy XPath即可复制元素的Xpath路径。...格式可能长这样: //*[@id="juejin"]/div[2]/main/div/div[1]/article/div[1] 获取元素Xpath路径的应用场景很多,比如我们经常使用的python...爬虫,利用爬虫框架可以通过Xpath路径很方便额控制页面中的某个dom节点,进而获取想要的数据和元素;又比如我们通过发送元素的Xpath路径给后端,后端可以统计某一功能的使用情况和交互数据;又比如分析用户在网站中浏览的热力分布图...3.js实现获取元素的Xpath路径 在实现之前,首先我们分析一下Xpath路径的结构,比如我们有一个页面,元素span的结构如下: <!

    1.5K30

    jquery获取第几个子元素_js获取元素的指定子元素

    可以这样理解,页面中的元素有相同的父元素 的,并且里面又包含li元素的,那么就取第一个li元素,每个子类集合都要进行判断,直到找出所有符合要求的li元素; :last-child:这个也与上面相对了,...An+B的所有子节点,比如3n+1返回所处位置为父节点子元素的是3的倍数加1的那个子元素; :even:页面范围内的处于偶数位置的元素,如:li:even返回全部偶数li元素; :odd:页面范围内的处于奇数位置的元素...(n):第n个匹配元素(不包括)之后的元素(n从0开始),如:ul:gt(2)返回从第3个ul开始的所有ul元素(含第三个); :lt(n):第n个匹配元素(不包括)之前的元素(n从0开始),如:ul...F的所有子元素(F可以为E的子类的子类,甚至更远); E>F:匹配父元素E下的所有标签名为F的直接子元素; E+F:匹配所有标签名为F的元素,并且有E类型的兄弟节点在该F元素之前(E,F紧挨着); E~...C等效于*.C; E#I:匹配id为I的所有元素E,#I等效于*#I; E[A]:匹配带有属性A的所有元素E; E[A=V]:匹配所有属性A的值为V的元素E; E[A^=V]:匹配所有元素E,且A的属性值是

    27.2K30

    每周学点测试小知识——WebDriver定位元素

    上周四下午的是芒果给大家介绍的自动化相关知识——WebDriver定位元素,在这里芒果给大家做个小介绍: 下面是这次课程的思维导图: 这里我们先来看看tag name的定位方式:大家也知道tag name...#定位一组元素 inputs = d.find_elements_by_tag_name("input") #对定位的元素进行遍历,找到符合条件的元素 for i in inputs: if...i.get_attribute("type")=="checkbox": i.click() 通过调用find_elements_by_tag_name我们可以获得所有tag name为“input”的元素...第一点,当我们要定位的页面元素有id属性时,最好尽量用id来定位,简单直接; 第二点,如果遇到少数元素确实找不到其他好的定位方式,我们可以选择稍微复杂xpath或css; 第三点,当要我们定位一组元素相同元素时...至于Selenium环境搭建、WebDriver介绍、其他的定位方式的使用小技巧

    20430

    【Web APIs】DOM 文档对象模型 ⑤ ( 获取特殊元素 | 获取 html 元素 | 获取 body 元素 )

    , 所有的元素都在 html 标签内部 , body 标签是显示部分内容的 顶层标签 ; 通过 JavaScript 和 DOM 操作 可以获取上述两个 html 和 body 特殊标签 元素 ; 1...、获取 html 元素 通过 document.documentElement 属性 , 可以获取文档中的 html 元素 , 该元素是 HTML 网页文档的最顶层元素 ; 代码示例 : const htmlElement...= document.documentElement; console.log(htmlElement); // 输出整个 元素的 DOM 对象 2、获取 body 元素 使用 document.body...> 元素的 DOM 对象 3、完整代码示例 在下面的代码中 , 通过 document.body 获取 body 元素 , 将背景颜色设置为黄色 ; 通过 document.documentElement...获取 html 元素 , 将该标签下的所有字体大小设置为 30 像素 ; 代码示例 : <!

    17110
    领券