zoukankan      html  css  js  c++  java
  • selenium3 + python

    一、css:属性定位

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

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

    <input id="kw" class="s_ipt" type="text" autocomplete="off" maxlength="100" name="wd"/>

        3.css用#号表示id属性,如:#kw

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

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

    from selenium import webdriver
    driver = webdriver.Chrome()
    driver.get("http://www.baidu.com")
    #用css通过id属性定位
    driver.find_element_by_css_selector("#kw").send_keys("selenium")
    #用css通过class属性定位
    driver.find_element_by_css_selector(".s_ipt").send_keys("selenium")

    二、css:其它属性

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

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

    from selenium import webdriver
    driver = webdriver.Chrome()
    driver.get("http://www.baidu.com")
    #用css通过autocomplete属性定位
    driver.find_element_by_css_selector("[autocomplete='off']").send_keys("selenium")
    #用css通过name属性定位
    driver.find_element_by_css_selector("[name='wd']").send_keys("selenium")
    #用css通过type属性定位
    driver.find_element_by_css_selector("[type='text']").send_keys("selenium")

    三、css:标签

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

    from selenium import webdriver
    driver = webdriver.Chrome()
    driver.get("http://www.baidu.com")
    #用css通过标签与name属性定位
    driver.find_element_by_css_selector("input.wd").send_keys("selenium")
    #用css通过标签与id属性定位
    driver.find_element_by_css_selector("inout#kw").send_keys("selenium")

    四、css:层级关系

     1.如xpath://form[@id='form']/span/input 和 //form[@class='fm']/span/input也可以用css实现

    from selenium import webdriver
    driver = webdriver.Chrome()
    driver.get("http://www.baidu.com")
    #css通过层级关系定位
    driver.find_element_by_xpath("span#s_kw_wrap>input").send_keys("selenium")
    driver.find_element_by_xpath("form.fm>span>input").send_keys("selenium")

    五、css:索引

       1.css也可以通过索引option:nth-child(1)来定位子元素,这点与xpath写法用很大差异,其实很好理解,直接翻译过来就是第几个小孩 

    #选择第一个option
    driver.find_element_by_css_selector("select#nr>option:nth-child(1)").click()
    #选择第二个option
    driver.find_element_by_css_selector("select#nr>option:nth-child(2)").click()
    #选择第三个option
    driver.find_element_by_css_selector("select#nr>option:nth-child(3)").click()

    六、css:逻辑运算

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

    from selenium import webdriver
    driver = webdriver.Chrome()
    driver.get("http://www.baidu.com")
    driver.find_element_by_css_selector("input[id='kw'][name='wd']").send_keys("selenium")

    七、css:模糊匹配 

     1.css的模糊匹配contains('xxx'),网上虽然用各种资料显示能用,但是小编亲自试验了下,一直报错。

     2.在各种百度后找到了答案:you can't do this with CSS selectors, because there is no such thing as:contains() in CSS. It was a proposal that was abandoned years ago.非常遗憾,这个语法已经被抛弃了,所以这里就没继续研究了。

    css语法远远不止上面提到的,还有更多更强大定位策略,有兴趣的可以继续深入研究。官方说法,css定位更快,语法更简洁,但是xpath更直观,更好理解一些。

  • 相关阅读:
    Potato工作流管理系统 组织模型用例描述
    6/27 项目编码开始:一个简单的员工管理程序
    6/16 6/17加班2天
    重新过一遍ASP.NET 2.0(C#)(8) DataSourceControl(数据源控件)
    可行性分析报告结构
    6/27 一个简单的员工管理程序:添加微软成员资格数据表
    在asp.net 2.0中使用母版页和工厂方法模式
    工作流功能特性
    6/21 系统分析阶段汇报
    什么是工作流
  • 原文地址:https://www.cnblogs.com/Teachertao/p/10965022.html
Copyright © 2011-2022 走看看