资讯专栏INFORMATION COLUMN

Selenium基本用法以及元素定位

番茄西红柿 / 2886人阅读

摘要:他支持手机浏览器,也支持等语言,支持如等操作系统,是一套为自动化测试量身定制的框架,框架由多个工具组成,包括,,和,至于他们的功能和作用请大家自行百度脑补,下面将重点介绍主要功能。

一、Selenium 简介

  Selenium是ThroughtWorks公司一个强大的开源Web功能测试工具系列,提供一套测试函数,用于支持Web自动化测试。函数非常灵活,能够完成界面元素定位、窗口跳转、结果比较。他支持IE、Firefox、Safari、Chrome、Android手机浏览器,也支持Java、C#、Python、Ruby、PHP等语言,支持如Windows、Linux、IOS、Android等操作系统,是一套为web自动化测试量身定制的web框架, Selenium框架由多个工具组成,包括:Selenium IDE,Selenium RC,Selenium WebDriver和SeleniumRC,至于他们的功能和作用请大家自行百度脑补,下面将重点介绍selenium主要功能WebDriver。

二、selenium基本功能

  1、浏览器并打开指定网页

  WebDriver driver = newChromeDriver();//初始化Google浏览器对象

  WebDriver driver = newFirefoxDriver();//初始化火狐浏览器

  WebDriver driver = new InternetExplorerDriver();//初始化IE浏览器

  driver.get(“www.baidu.com”)//打开百度页面

  driver.close();//关闭当前页面

  driver.quit();//关闭由selenium所启动的所有页面

  备注:有些浏览器比如火狐并没有安装在默认路径,那么需要指定浏览器路径:System.setProperty("webdriver.firefox.bin","D:Program FilesMozilla Firefoxfirefox.exe");

  2、浏览器操作  

  driver.navigate().back();//返回或向前
  driver.navigate().forward();//向后
  driver.navigate().refresh();//刷新
  driver.manage().window().maxsize();//最大画窗口 

  String title = driver.getTitle(); //返回当前页面的Ttile
  String currentUrl = driver.getCurrentUrl(); //返回当前页面的url
  getPageSource() //返回当前页面的源码
  getWindowHandle() //返回当前的浏览器的窗口句柄
  getWindowHandles() //返回当前的浏览器的所有窗口句柄

  备注:对于句柄等的介绍后续会有详细篇幅进行介绍,此处不做赘述

三、基本元素定位

 a、元素定位: 

 例子:

  

  1、By.id(id) //用唯一属性id来定位非常推荐使用 优先级最高
  2、By.name(name) //用name属性来定位也是非常高效的优先级仅次于id
  3、By.linkText(linkText) //即通过超文本链接上的"文字信息"来定位元素,这种方式一般专门用于定位页面上的超文本链接:一般tag为属性href=链接
  4、By.partialLinkText(linkText) //适用于链接类的元素,模糊匹配,即包含herf属性的元素 ,同BylinkText()
  5、By.className(className)) //对于元素的属性包含class的情况适用
  6、By.tagName(name) //通用定位方式,适用于层级定位,比如button就是一个tag 因此一般都会找出多条记录,需要在进行定位,通常用for循环

  以上均为单元素定位,当然6一般定位的结果都是多个,其他的一般结果为1个。单元素定位的命令基本格式如下:

  WebElemet element = driver.findElement(By.id("imageField"));

  element.click();//点击

  element.sendKeys("String");//输入

  备注:有一个现象,就是复合类,即例子中的class="gbqfba sb_bs">,如果用driver.findElement(By.id("gbqfba sb_bs"))一定会报错,这种复合类必须用前面的或者后面的键值才能定位成功,即:driver.findElement(By.id("sb_bs"))or driver.findElement(By.id("gbqfba")),否则会报错,但是注意,如果class="gbqfba:sb_bs">这不是符合类,可以自行脑补一下css

 b、多元素定位:

  多元素定位其实是指定位的元素返回多个结果,一般会用List集合来存储结果,用for循环和if判断语句来找到自己需要的元素,比如用tagName定位,返回的结果就会多个如下:  

  List allInputs = driver.findElements(By.tagName("input"));//定位tagName为input的tag元素
  for(WebElement element :allInputs){
    if(element.getAttribute("type").equals("text")){
      System.out.println(e.getText().toString()); //打印出每个文本框里的值
    }
  }

 c、层级定位

  层级定位,顾名思义,就按照层级关系进行定位,一般是应用于无法直接定位到需要定位的元素,所以采用先定位其父元素,在定位子元素的方式,一般用于表格或下拉框定位:

  表格应用

  WebElement table = driver.findElement(By.id("table"));

  List rows  = table.findElement(By.id("tr"));

  下拉框应用

  WebElement select = driver.findElement(By.name("select")); //

  List selectvalue = a.findElements(By.tagName("option"));

  for(WebElement value : selectvalue){

    System.out.println(“value”+value.getText())

  }

 e、xpath定位

  Xpath是一个非常强大的定位方式,几乎可以定位到所有数据,但是在我们学习Xpath定位之前,我们要知道明确两个概念,绝对路径&相对路径,绝对路径是以“/”开始的,

  例如/body/buttononclick/input[1], 这就是绝对路径的表达形式,相反“相对路径”是以“//”开头的,比如//input[2],另外需要多说一句的是,当xpath的路径以"/"开头时,表示

  让Xpath解析引擎从文档的根节点开始解析。当xpath路径以"//"开头时,则表示让xpath引擎从文档的任意符合的元素节点开始进行解析。而当/出现在xpath路径中时,则表示

  寻找父节点的直接子节点,当"//"出现在xpath路径中时,表示寻找父节点下任意符合条件的子节点,不管嵌套了多少层级(这些下面都有例子,大家可以参照来试验)。弄清

  这个原则,我们就可以灵活的使用 Xpaht进行定位了,下面还是看几个"栗子"吧  

  查找页面根元素://
  查找页面上所有的input元素://input

  查找页面上第一个form元素内的直接子input元素(即只包括form元素的下一级input元素,使用绝对路径表示,单/号)://form[1]/input

  查找页面上第一个form元素内的所有子input元素(只要在form元素内的input都算,不管还嵌套了多少个其他标签,使用相对路径表示,双//号)://form[1]//input

  查找页面上第一个form元素://form[1]

  查找页面上id为loginForm的form元素://form[@id=loginForm]

  查找页面上具有name属性为username的input元素://input[@name=username]

  查找页面上id为loginForm的form元素下的第一个input元素://form[@id=loginForm]/input[1]

  查找页面具有name属性为contiune并且type属性为button的input元素://input[@name=continue][@type=button]

  查找页面上id为loginForm的form元素下第4个input元素://form[@id=loginForm]/input[4]

  查找页面上id是以“myid"开始/结尾关键字的元素://img[starts-with(@id,myid)]  //img[ends-with(@id,myid)] 

  查找页面上id属性包含g1关键字的元素://img[contains(@id,g1)]

    查找页面上文本是“百度搜索”的所有元素://a[text()=百度搜索]      //a[contains(text(),"搜索")] --文本模糊定位

  查找页面上input的最有一个元素://input[last()]  函数位置定位

  a、通过路径定位

  WebElement xpath = driver.findElement(By.xpath("html/body/div/form/input"));

  WebElement xpath = driver.findElement(By.xpath("//input"))

  b、通过索引定位

  WebElement xpath = driver.findElement(By.xpath("//input[3]"));

  c、通过属性定位

  WebElement xpath = driver.findElement(By.xpath(""//*[@id=su and @type=submit]""));

  WebElement xpath = driver.findElement(By.xpath(""//*[@id=su][type=submit]""));

  d、文本属性定位

  WebElement xpath = driver.findElement(By.xpath("//div[@class=qrcode-text]/p/b[text()=百度]"));

  e、模糊匹配

  WebElement xpath = driver.findElement(By.xpath("//input[starts-with(@id,su)"));

  WebElement xpath = driver.findElement(By.xpath("//input[ends-with(@id,su)"));

  WebElement xpath = driver.findElement(By.xpath("//input[contains(@id,su)"));

  WebElement xpath = driver.findElement(By.xpath(""//*[@id=su][type=submit]""));

  代码实例:WebElement xpath = driver.findElement(By.xpath("//form[@id=loginForm]"))

  xpath定位就介绍这些,后续还会更新关于Cssselect、js定位、下拉框、单选/多选框、文本框、弹窗、句柄等,敬请关注

  小技巧:
  1.当页面元素有id属性时,最好尽量用id来定位。但由于现实项目中很多程序员其实写的代码并不规范,会缺少很多标准属性,这时就只有选择其他定位方法。

  2.xpath很强悍,但定位性能不是很好,所以还是尽量少用。如果确实少数元素不好定位,可以选择xpath或cssSelector。如果自动化案例中使用大量的Xpath进行定位,你会发现你的脚本执行时间非常的长,慎用。

  3.当要定位一组相同元素时,可以考虑用tagName或name。

  4.当有链接需要定位时,可以考虑linkText或partialLinkText方式。

     5.在进行定位的时候,尽量使用相对路径定位,如果使用绝对路径,那么一但页面结构变化,则无法使用原有的定位方式,但是相对路径就特别灵活,复用性高,也是项目中特别常用的方式

  

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/2202.html

相关文章

  • ❤️爬虫+自动化利器 selenium 之自学成才篇(一)❤️

    文章目录 selenium 简介selenium安装安装浏览器驱动确定浏览器版本下载驱动 定位页面元素打开指定页面id 定位name 定位class 定位tag 定位xpath 定位css 定位link 定位partial_link 定位 浏览器控制修改浏览器窗口大小浏览器前进&后退浏览器刷新浏览器窗口切换常见操作 鼠标控制单击左键单击右键双击拖动鼠标悬停 键盘控制 seleni...

    james 评论0 收藏0
  • Selenium常用方法(Python)

    摘要:概述是一款开源的自动化框架,模拟用户操作浏览器的行为,主要用于界面自动化浏览器兼容性测试。将浏览器原生的封装成,作为编程语言与浏览器通信的桥梁,从而达到操作浏览器的目的。 ...

    Aceyclee 评论0 收藏0
  • 【Python爬虫】4万字,详解selenium从入门到实战【错过再无】

    摘要:难在哪里根据上面的标签需要定位最后一行标签,以下列出了四种方式,定位的方式多样并不唯一,使用时根据情况进行解析即可。加入每日一练我们使用并指明标签内全部文本即可定位。 ...

    shiyang6017 评论0 收藏0
  • 以后再有人问你selenium是什么,你就把这篇文章给他

    摘要:不同目标的自动化测试有不同的测试工具,但是任何工具都无不例外的需要编程的过程,实现源代码,也可以称之为测试脚本。 写在最前面:目前自动化测试并不属于新鲜的事物,或者说自动化测试的各种方法论已经层出不穷,但是,能够在项目中持之以恒的实践自动化测试的团队,却依旧不是非常多。有的团队知道怎么做,做的还不够好;有的团队还正在探索和摸索怎么做,甚至还有一些多方面的技术上和非技术上的旧系统需要重构……...

    Keven 评论0 收藏0
  • 动态HTML介绍 & Selenium PhantomJS

    摘要:一个网站使用的特征就是源代码里包含了入口比如如果你在一个网站上看到了,那么采集这个网站数据的时候要格外小心。直接点击下拉框中的选项不一定可行。未审核初审通过复审通过审核不通过专门提供了类来处理下拉框。 JavaScript JavaScript 是网络上最常用也是支持者最多的客户端脚本语言。它可以收集 用户的跟踪数据,不需要重载页面直接提交表单,在页面嵌入多媒体文件,甚至运行网页游戏。...

    Lsnsh 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<