51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 971|回复: 0
打印 上一主题 下一主题

selenium 下拉列表框定位及文本获取

[复制链接]
  • TA的每日心情
    无聊
    8 小时前
  • 签到天数: 938 天

    连续签到: 5 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2022-12-2 15:52:35 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    1.通过先定位到具体的元素然后通过text方法获取文本信息,如获取控件名称等。
      driver.find_element_by_xpath("//div[/h1").text

      2.直接通过定位到的元素的属性直接获取属性名称,如输入框提示信息等。
      driver.find_element_by_id("XXX").get_attribute(YYY)

      启发:元素的定位可以先定位到大的颗粒度,在向小的颗粒度定位,例如先定位到table,在定位到table中的行和列。
      代码如下:
      此处为写的获取第一列元素的list的方法。

    如果得到的文本只为空,而非我们期望的baidu,那么当前定位的元素可能被隐藏了。
      1.判断是否被隐藏 。
      driver.find_element_by_xx().is_displayed()  

      打印结果,如果得到 false的结果.那就说明被隐藏了。
      2.怎么解决?
      方法一:   修改页面当前定位元素,或者当前元素父元素的CSS,使元素的is_displayed()  值为true。
      方法二:  is_displayed()  为false的元素,依然可以通过getAttribute()方法获取元素的属性.。
      由于webdriver spec的定义,[url=]Selenium[/url] WebDriver 只会与可见元素交互,所以获取隐藏元素的文本总是会返回空字符串。
      可是,在某些情况下,我们需要获取隐藏元素的文本。这些内容可以使用element.attribute('attributeName'), 通过textContent, innerText, innerHTML等属性获 取。(划重点)
      innerHTML 会返回元素的内部 HTML, 包含所有的HTML标签。
      例如,<div>Hello <p>World!</p></div>的innerHTML会得到Hello <p>World!</p>
      textContent 和 innerText 只会得到文本内容,而不会包含 HTML 标签。
      textContent 是 W3C 兼容的文字内容属性,但是 IE 不支持
      innerText 不是 W3C DOM 的指定内容,FireFox不支持
      1、Select元素
      1.打开百度-设置-搜索设置界面,如下图所示:

     2.箭头所指位置,就是 select 选项框,打开页面元素定位,下方红色框框区域,可以看到 select 标签属性:
      <select id="nr" name="NR">

      3.选项有三个
      <option selected="" value="10">每页显示 10 条</option>
      <option value="20">每页显示 20 条</option>
      <option value="50">每页显示 50 条</option>


      2、定位select
      定位select有多种方法,下面进行一一介绍。
      2.1 二次定位
      1.定位 select 里的选项有多种方式,这里先介绍一种简单的方法:二次定位。
      2.基本思路,先定位 select 框,再定位 select 里的选项。
      完整代码如下:


    3.还有另外一种写法也是可以的,把最下面两步合并成为一步:
      driver.find_element_by_id("nr").find_element_by_xpath("//option[@value='50']").click()

       2.2 直接定位
      1.有很多小伙伴说 firebug 只能定位到 select 框,还能定位里面的选项。
      2.用 direbug 定位到 select 后,下方查看元素属性地方,点 select 标签前面的+号,就可以展开里面的选项内容了。


    3.然后自己写 xpath 定位或者 css,一次性直接定位到 option 上的内容。
        完整代码如下:


    2.3  Select  模块(index)点位  
      1.除了上面介绍的两种简单的方法定位到 select 选项,selenium 还提供了更高级的玩法,导入 Select 模块。直接根据属性或索引定位。
      2.先要导入 select 方法:
      from selenium.webdriver.support.select import Select

      3.然后通过 select 选项的索引来定位选择对应选项(从 0 开始计数),如选择第三个选项:select_by_index(2)
      完整代码如下:

    2.4 Select  模块(value)定位
      1.Select 模块里面除了 index 的方法,还有一个方法,通过选项的 value值来定位。每个选项,都有对应的 value 值,如:
      <select id="nr" name="NR">
      <option selected="" value="10">每页显示 10 条</option>
      <option value="20">每页显示 20 条</option>
      <option value="50">每页显示 50 条</option>


      2.第二个选项对应的 value 值就是“20”:select_by_value(2)
        完整代码如下:

      2.5  Select  模块(text)定位
      1.Select 模块里面还有一个更加高级的功能,可以直接通过选项的文本内容来定位。
      2.定位“每页显示 50 条”:select_by_visible_text("每页显示 50 条")
        完整代码如下:

      3.Select  模块其它方法
      select 里面方法除了上面介绍的三种,还有更多的功能如下:

      ·select_by_index() :通过索引定位
      · select_by_value() :通过 value 值定位
      · select_by_visible_text() :通过文本值定位
      · deselect_all() :取消所有选项
      · deselect_by_index() :取消对应 index 选项
      · deselect_by_value() :取消对应 value 选项
      · deselect_by_visible_text() :取消对应文本选项
      · first_selected_option() :返回第一个选项
      · all_selected_options() :返回所有的选项






    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-4-26 17:42 , Processed in 0.067608 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表