Selenium几种元素定位方式

  1. Selenium提供的几种定位方式
    # 根据元素id进行查找
    dr.find_element_by_id('id')
    # 根据name属性值进行查找
    dr.find_element_by_name('name')
    # 根据类名进行查找
    dr.find_element_by_class_name('classname')
    # 根据css选择器进行查找
    dr.find_element_by_tag_name('css_expression')
    # 根据xpath进行查找
    dr.find_element_by_xpath('xpath_expression')
    # 根据链接文本进行查找
    dr.find_element_by_link_text('link_text')
    # 根据链接为本进行模糊匹配
    dr.find_element_by_partial_link_text('partial_pattern')

     

  2. 定位方式一般情况下的优先级
    总的原则其实是哪种方式能得到唯一精确的结果就用哪个。在都不能得到精确结果的时候,几种常用的方式的优先级顺序为:
    id-name-class-css_selector-xpath-其它

    为何css_selector的优先级高于xpath:
        a) css是针对html的,实现的原理与css中匹配对象的机制,而xpath对应配合xml工作,它实现的原理是遍历的原理,显然css性能更优
        b) 表达式相对xpath往往要简单很多
        c) 前端开发主要用css,所以在元素定位困难时,也更易于和开发进行沟通
  3. css_selector与xpath的语法
    # css_selector语法
    
    # 1.id选择器:#id
    # 2.class选择器:.class
    # 3.标签选择器:E(标签名称)
    # 4.子元素选择器:E>F, E元素的所有子元素F
    # 5.后代元素选择器:E F. 所有E元素的后代元素F
    # 6.毗邻元素选择器:E+F, 紧随E元素之后的同级元素F(只匹配第一个)
    # 7.同级元素选择器:E~F, 所有在E元素之后的同级元素F
    # 8.正则表达式规则查找:
            E[att^='val'], att以val开头的元素E
            E[att$='val'],att以val结尾的元素E
            E[att*='val'], att包含val的元素E
            E[att1='v1'][att2='v2'], att1为v1,att2为v2的元素E
            E:contains('xxxx') 内容包含xxxx的元素E
    
    # xpath语法
    # 1.全路径定位:/html/body/table/....
    # 2.节点属性://input(@value='内容')
    # 3.节点文本://option[text()='内容']
    # 4.关联属性定位://input(@type='' and @value='')
    # 5.父节点定位://table[@class='']/thead[@class='']
    # 6.下标定位://*[@id='']/td[2]
    # 7.模糊匹配属性://tr[contains(@id, '***')]/td[2]

     

  4. 补充
    # 除上述定位方式外,还有一个通用的API:find_element()
    from selenium.webdriver.common.by import By
    from selenium import webdriver
    
    dr = webdriver.Chrome()
    dr.get("http://www.baidu.com")
    dr.find_element(By.ID, 'id')

     

你可能感兴趣的:(python,UI自动化测试)