PhantomJS + Selenium webdriver 总结-元素定位

  webdriver提供了丰富的API,有多种定位策略:id,name,css选择器,xpath等,其中css选择器定位元素效率相比xpath要高些,使用id,name属性定位元素是最可靠,效率最高的一种办法。

  1、元素定位的方法:find_element() 与find_elements()

    find_element() 该方法返回基于指定查询条件的webElement对象,或抛出不符合条件的异常  eg:element = driver.find_element(By.ID,‘u1‘)

    findElements() 该方法返回指定查询条件的WebElement的对象集合,或抛出不符合条件的异常

  2、WebElement对象提供的各种定位元素策略

    ID:driver.findElement(By.ID,‘elementID‘)    

    Name:driver.findElement(By.NAME,‘elementName‘)

    className:driver.findElement(By.CLASS_NAME,‘elementClassName‘)        

    tagName:driver.findElement(By.TAG_NAME,‘htmlTagName‘)

     linkText:driver.findElement(By.LINK_TEXT,‘linkText‘)

    partialLinkText:driver.findElement(By.PARTIAL_LINK_TEXT,‘partialLinkText‘)

    css:driver.findElement(By.CSS_SELECTOR,‘cssSelector‘)

    xpath:driver.findElement(By.XPATH,‘xpathQuery‘) 

 

    例如:url =‘https://www.baidu.com/‘

    driver.find_element(By.ID,‘u1‘)

     driver.find_element(By.NAME,‘tj_trnews‘)

     driver.find_elements(By.CLASS_NAME,‘mnav‘)

     driver.find_element(By.ID,‘u1‘).find_elements(By.TAG_NAME,‘a‘)

     driver.find_element(By.ID,‘u1‘).find_element(By.LINK_TEXT,‘新闻‘)

     driver.find_element(By.ID,‘u1‘).find_element(By.PARTIAL_LINK_TEXT,‘闻‘)

     driver.find_elements(By.CSS_SELECTOR,"a[name^=‘tj‘]") #匹配属性值name以tj开头的元素

    driver.find_elements_by_xpath("//div[@id=‘u1‘]/a")

  

  3、使用元素的任何属性来定位元素

    driver.find_element(By.CSS_SELECTOR("标签名[属性名=‘属性值‘]"))

    1、^=        driver.find_element(By.CSS_SELECTOR("标签名[属性名^=‘xxx‘]"))  匹配属性值以xxx开头的元素

          例如:driver.find_elements(By.CSS_SELECTOR,"a[name^=‘tj‘]")  匹配name值以tj开头的a元素集合

    2、$=        driver.find_element(By.CSS_SELECTOR("标签名[属性名$=‘xxx‘]"))  匹配属性值以xxx结尾的元素

           例如:driver.find_elements(By.CSS_SELECTOR,"a[name$=‘s‘]")  匹配name值以s结尾的a元素集合

     3、*=         driver.find_element(By.CSS_SELECTOR("标签名[属性名*=‘xxx‘]"))  匹配属性值包含xxx的元素

           例如:driver.find_elements(By.CSS_SELECTOR,"a[name*=‘tr‘]")  匹配name值包含tr的a元素集合

 

时间: 2024-11-09 10:45:29

PhantomJS + Selenium webdriver 总结-元素定位的相关文章

【Selenium WebDriver】元素定位函数 FindElement

定位Web页面上的元素,用FindElement函数,它可以根据元素的不同属性来快速定位.具体的属性如下: 例子: HTML页面文件: 1 <html xmlns="http://www.w3.org/1999/xhtml" lang="en-us"> 2 <head> 3 <body> 4 <form name="loginForm"> 5 <label for="username

[selenium webdriver Java]元素定位——findElement/findElements

策略 语法 语法 描述 By id driver.findElement(By.id()) driver.findElements(By.id()) 通过id属性定位元素 By name driver.findElement(By.name()) driver.findElements(By.name()) 通过name属性定位元素 By class name driver.findElement(By.className()) driver.findElements(By.className(

selenium webdriver 表格的定位方法练习

selenium webdriver 表格的定位方法 html 数据准备 <html> <body> <div id="div1"> <input name="divl1input"></input> <a href="http://www.sogou.com/">搜狗搜索</a> <img alt="div1-img1 "src=&qu

selenium+python之元素定位方式介绍

网页自动化测试最基本的要求就是要定位到各个元素,然后才能对该元素进行各种操作(输入,点击,清除,提交等),所以今天来总结下Selenuim+Python最基本的几种定位方式及实例说明, 以百度搜索输入框为例,用谷歌浏览器具体说明各个定位方式的用法. 1.导入selenium包的webdriver方法 输入 from selenium import webdriver 2.从 time 模块中引入sleep函数,使用sleep函数可以让程序休眠 输入 from time import sleep

selenium自动化测试之元素定位一

Selenium元素定位方法总共有八大类,分别是:id,name,class name,tag name,link text,partial link text,xpath,css.八种定位方法没有哪个是最好的,在不同的场景下需要使用不用的定位方法. 示例html文件如下: <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="utf-8"/> <me

selenium webdriver XPath的定位方法练习 !

html  代码: <html> <body> <div id="div1"> <input name="divl1input"></input> <a href="http://www.sogou.com/">搜狗搜索</a> <img alt="div1-img1 "src="http://www.sogou.com/ima

【Selenium专题】元素定位之CssSelector

CssSelector是我最喜欢的元素定位方法,Selenium官网的Document里极力推荐使用CSS locator,而不是XPath来定位元素,原因是CSS locator比XPath locator速度快,特别是在IE下面(IE没有自己的XPath 解析器(Parser))他比xpath更高效更准确更易编写,美中不足是根据页面文字时略有缺陷没有xpath直接. 因为前端开发人员就是用CSS Selector设置页面上每一个元素的样式,无论那个元素的位置有多复杂,他们能定位到,那我们使用

【selenium专题】元素定位之多层框架和窗口

本节知识点 多层框架或窗口切换样式:WebDrvier.switchto().TargetLocator Interface WebDriver.TargetLocator下所有可切换对象 参考API-Interface WebDriver.TargetLocator WebDriver  driver= new FirefoxDriver();//启动firefox浏览器 driver.manage().window().maximize(); 1.切换frame driver.switchT

selenium基础:元素定位之css_selector和轴定位

selenium提供了非常丰富的元素定位方式,下面一张思维导图是我根据工作经验总结的定位元素方式,还是比较全的 本篇博客重点介绍css_selector定位和轴定位 一 轴定位 轴名称 ancestor:祖先节点,包含父节点和祖父节点 parent:父结点 preceding_sibling:当前节点标签前的所有兄弟节点 following_sibling:当前节点标签后的所有兄弟节点 following:当前节点标签后的所有节点 使用语法 /轴名称::节点名称  注:轴定位最好用单斜杠 例子