51Testing软件测试论坛

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

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 2035|回复: 1
打印 上一主题 下一主题

selenium自动化测试入门 获取元素对象

[复制链接]
  • TA的每日心情
    郁闷
    2022-8-29 14:43
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    跳转到指定楼层
    1#
    发表于 2018-2-6 15:58:39 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
            一、元素定位简介
           八种属性定位页面元素:

           By.ID
           By.XPATH
           By.LINK_TEXT
           By.PARTIAL_LINK_TEXT
           By.NAME
           By.TAG_NAME
           By.CLASS_NAME
           By.CSS_SELECTOR


           webdriver元素定位方法:
    1. driver.find_element(By.XXX,'元素属性')  # 定位单个元素
    2. driver.find_elements(By.XXX,'元素属性')  # 定位一组元素,返回list列表
    复制代码
          webdriver中元素定位元素的简便方法:
    1. driver.find_element_by_id('元素id属性')  # ------ 最常用,简单
    2. driver.find_element_by_name('元素name属性')  # ------ 最常用,简单
    3. driver.find_element_by_class_name('元素class属性')  # ------ 易重复,看情况使用
    4. driver.find_element_by_tag_name('元素标签名')  # ------ 最不靠谱
    5. driver.find_element_by_link_text('链接文本')  # ------ 精确匹配链接 (<a> 标签中的文字)
    6. driver.find_element_by_partial_link_text(‘部分链接文本’)  # ------ 模糊匹配链接
    7. driver.find_element_by_xpath()  # ------ 最灵活,万能的灵药
    8. driver.find_element_by_css_selector()  # ------ 没xpath灵活
    复制代码
          如果需要使用简便的方法点位一组元素,在element后加个s,如,river.find_elements_by_id() ;
    它返回的也是 list列表。

           二、怎么获取元素属性?

           第一种:Chrome或者Firefox 打开网页,在需要获取属性的元素上[右键 ==> 检查(or查看元素)]

           第二种:Chrome或者Firefox 打开网页,按F12(开发者选项),选择左上角的鼠标指针后单击页
    面元素


           三、获取页面元素

           1、id元素定位

           <input id="query" class="sec-input" name="query" maxlength="100" autocomplete="off" type="text">

    1. driver.find_element_by_id(‘query’)
    复制代码
          2、name元素定位

           <input id="query" class="sec-input" name="query" maxlength="100" autocomplete="off" type="text">

    1. driver.find_element_by_name(‘query’)
    复制代码
          3、class name元素定位

           <input id="query" class="sec-input" name="query" maxlength="100" autocomplete="off" type="text">

    1. driver.find_element_by_class_name(‘sec-input’)
    复制代码
          4、 tag name元素定位(最不靠谱)

           <input id="query" class="sec-input" name="query" maxlength="100" autocomplete="off" type="text">

    1. driver.find_element_by_tag_name(‘input’)
    复制代码
          5、 link_text元素定位

           页面底部搜狗输入法连接

           <a uigs-id="mid_pinyin" href="http://pinyin.sogou.com/" target="_blank"><i class="i1"></i>搜狗输入法</a>

    1. driver.find_element_by_link_text('搜狗输入法')
    复制代码
          注意:连接文本是<a></a>标签对之间的文本
           6、 partial link text元素定位


           <<a uigs-id="mid_pinyin" href="http://pinyin.sogou.com/" target="_blank">
    <i class="i1"></i>搜狗输入法</a>

    1. driver.find_element_by_partial_link_text(‘输入法’)
    复制代码
          7、 XPath元素定位(强大)

           学习资料: http://www.w3school.com.cn/xpath/

           xpath 可以根据元素的父节点或者哥哥弟弟节点定位到元素。


    1. driver.find_element_by_xpath(‘//form[@id="sf"]//input[@type="text"]’) # 上级节点定位下级子节点
    2. driver.find_element_by_xpath(‘//span[@class="enter-input"]/preceding-sibling::span/input’)  # 通过节点的弟弟节点定位
    复制代码
          注意:使用xpath最好不要使用工具获取,手写的可靠性更高
           8、css元素定位

           css定位元素比xpath块,id,name,class,tag name都是转换为css后定位元素。具体请看
    find_element方法的代码。

           <input id="query" class="sec-input" name="query" maxlength="100" autocomplete="off"
    type="text">

    1. driver.find_elements_by_css_selector(".sec-input")  #  .表示class
    2. driver.find_elements_by_css_selector("#query")   #  #表示id
    复制代码
          四、xpath 与 css 对照表



    本帖子中包含更多资源

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

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

    使用道具 举报

    本版积分规则

    关闭

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

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

    GMT+8, 2024-11-18 02:25 , Processed in 0.067880 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

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