• Selenium3+python3自动化(七)--CSS定位语法


    前言

    大部分人在使用selenium定位元素时,用的是xpath定位,因为xpath基本能解决定位的需求。css定位往往被忽略掉了,其实css定位也有它的价值,css定位更快,语法更简洁。

    一、css:属性定位

    1.css可以通过元素的id、class、标签这三个常规属性直接定位到

    2.如下是百度输入框的html代码:

    <input id="kw" name="wd" class="s_ipt" value="" maxlength="255" autocomplete="off">

    3.css用#表示id属性,如:#kw;也可以写成[id='kw']

    4.css用.表示class属性,如.s_ipt

    5.css直接用标签名称,无任何标识符,如:input

    # coding:utf-8
    from selenium import webdriver
    driver=webdriver.Chrome()
    driver.get("https://www.baidu.com")
    #css通过id属性定位
    # driver.find_element_by_css_selector("#kw").send_keys("xixi")
    #css通过class属性定位
    # driver.find_element_by_css_selector(".s_ipt").send_keys("hehe")
    #css通过标签属性定位,这里运行会报错,主要是了解这个写法
    driver.find_element_by_css_selector("input").send_keys("wrong")  

     二、css:其它属性

    1.css除了可以通过标签、class、id这三个常规属性定位外,也可以通过其它属性定位

    2.以下是定位其它属性的格式

    # coding:utf-8
    from selenium import webdriver
    driver=webdriver.Chrome()
    driver.get("https://www.baidu.com")
    #css通过name属性定位
    # driver.find_element_by_css_selector("[name='wd']").send_keys("xixi")
    #css通过autocomplete属性定位
    driver.find_element_by_css_selector("[autocomplete='off']").send_keys("hehe")
    

     三、css:标签

    1.css页可以通过标签与属性的组合来定位元素

    # coding:utf-8
    from selenium import webdriver
    driver=webdriver.Chrome()
    driver.get("https://www.baidu.com")
    #css通过标签与class属性的组合定位
    # driver.find_element_by_css_selector("input.s_ipt").send_keys("xixi")
    #css通过标签与id属性的组合定位
    # driver.find_element_by_css_selector("input#kw").send_keys("hehe")
    #css通过标签与其它属性组合定位
    driver.find_element_by_css_selector("input[autocomplete='off']").send_keys("hua")  

     四、css:层级关系

    1.在前面一篇xpath中讲到层级关系定位,这里css也可以达到同样的效果

    2.如xpath://form[@id='form']/span/input 也可以用css实现;

    # coding:utf-8
    from selenium import webdriver
    driver=webdriver.Chrome()
    driver.get("https://www.baidu.com")
    #xpath
    #driver.find_element_by_xpath("//form[@id='form']/span/input").send_keys("hu")
    # driver.find_element_by_xpath("//span/*[@name='wd']").send_keys("hehe")
    #css通过层级关系定位
    #driver.find_element_by_css_selector("form#form>span>input").send_keys("hehe")
    driver.find_element_by_css_selector("span>input[name='wd']").send_keys("hehe")
    

     五、css:索引

    1.以下图为例,跟上一篇一样

     2.css也可以通过索引a:nth-child(1)来定位元素

    # coding:utf-8
    from selenium import webdriver
    driver=webdriver.Chrome()
    driver.get("https://www.baidu.com")
    #选择第一个a
    driver.find_element_by_css_selector("div[id='s-top-left']>a:nth-child(1)").click()
    #选择第3个a
    # driver.find_element_by_css_selector("div#s-top-left>a:nth-child(3)").click()
    

     六、css:逻辑运算

     1.css同样也可以实现逻辑运算,同时匹配两个属性,这里跟xpath不一样,无需写and关键字

    # coding:utf-8
    from selenium import webdriver
    driver=webdriver.Chrome()
    driver.get("https://www.baidu.com")
    # driver.find_element_by_css_selector("input#kw[name='wd']").send_keys("he")
    driver.find_element_by_css_selector("input[id='kw'][name='wd']").send_keys("xixi")
    

     七、css模糊匹配

    [abc^="def"] 选择 abc 属性值以 "def" 开头的所有元素
    [abc$="def"] 选择 abc 属性值以 "def" 结尾的所有元素
    [abc*="def"] 选择 abc 属性值中包含子串 "def" 的所有元素

    越努力,越幸运!!! good good study,day day up!!!
  • 相关阅读:
    OpenMP并行程序设计
    Snmp在Windows下的实现WinSNMP编程原理
    利用C#开发基于snmpsharpnet基础的SNMP开发应用
    SNMP用VC实现的方法
    题目
    C# combox问题
    网络管理Snmp
    error BK1506
    响应activex事件
    使用C# 连接不同版本的Oracle.DataAccess
  • 原文地址:https://www.cnblogs.com/canglongdao/p/13568452.html
Copyright © 2020-2023  润新知