zoukankan      html  css  js  c++  java
  • 基础selenium+Python(定位、等待、打印)

    1、第一个脚本

    # coding = utf-8
    from selenium import webdriver
    browser = webdriver.Firefox()
    browser.get("http://www.baidu.com")
    browser.find_element_by_id("kw" ).send_keys( "selenium")
    browser.find_element_by_id("su").click()
    browser.close()

    1.1  脚本解析
    # coding = utf-8
    可加可不加,开发人员喜欢加一下,防止乱码嘛。
    from selenium import webdriver
    使用 selenium 的 webdriver 里的函数,首先把包导进来
    browser = webdriver.Firefox()
    需要操控哪个浏览器呢,Firefox ,当然也可以换成 Ie 或 Chrome 。browser 可以
    随便取,但后面要用它操纵各种函数执行。
    browser.find_element_by_id("kw").send_keys("selenium")
    一个控件有若干属性 id 、name、(也可以用其它方式定位),百度输入框的 id 叫 kw ,
    browser.find_element_by_id("su").click()
    搜索的按钮的 id 叫 su ,我需要点一下按钮( click() )。
    browser.quit()
    退出并关闭窗口的每一个相关的驱动程序,
    browser.close()
    关闭当前窗口 ,用哪个看你的需求了。

    2、元素的定位

    对象的定位应该是自动化测试的核心,要想操作一个对象,首先应该识别这个对象。
    一个对象就是一个人一样,他会有各种的特征(属性)。
    那么一个对象也有类似的属性,我们可以通过这个属性找到这对象。
    webdriver 提供了一系列的对象定位方法,常用的有以下几种
     · id
     · name
     · class name
     · link text
     · partial link text
     · tag name
     · xpath
     · css selector
    我们可以看到,一个百度的输入框,可以用这么用种方式去定位。
    <input id="kw" class="s_ipt" type="text" maxlength="100" name="wd"autocomplete="off">

    #coding=utf-8
    from selenium import webdriver
    browser = webdriver.Firefox()
    browser.get("http://www.baidu.com")
    #########百度输入框的定位方式##########
    #通过 id 方式定位
    browser.find_element_by_id("kw").send_keys("selenium")
    #通过 name 方式定位
    browser.find_element_by_name("wd").send_keys("selenium")
    #通过 tag name 方式定位
    browser.find_element_by_tag_name("input").send_keys("selenium")
    #通过 class name 方式定位
    browser.find_element_by_class_name("s_ipt").send_keys("selenium")
    #通过 CSS 方式定位
    browser.find_element_by_css_selector("#kw").send_keys("selenium")
    #通过 xphan 方式定位
    browser.find_element_by_xpath("//input[@id='kw']").send_keys("selenium")
    browser.find_element_by_id("su").click()
    time.sleep(3)
    browser.quit()

    2.1 id 和 和 name 定位

    id 和 name 是我们最最常用的定位方式,因为大多数控件都有这两个属性,而且在对控件的 id 和 name 命名时一般使其有意义也会取不同的名字。通过这两个属性使我
    们找一个页面上的属性变得相当容易我们通过前端工具,找到了百度输入框的属性信息,如下:
    <input id="kw" class="s_ipt" type="text" maxlength="100" name="wd"autocomplete="off">
    id=”kw” :通过 find_element_by_id("kw") 函数就是捕获到百度输入框
    name=”wd”:通过 find_element_by_name("wd")函数同样也可以捕获百度输入框

    2.2 tag name 和 和 class name 定位

    从上面的百度输入框的属性信息中,我们看到,不单单只有 id 和 name 两个属性,比如 class 和 tag name(标签名)
    <input id="kw" class="s_ipt" type="text" maxlength="100" name="wd"autocomplete="off">
    <input>:input 就是一个标签的名字,可以通过 find_element_by_tag_name("input") 函数来定位。
    class="s_ipt":通过 find_element_by_class_name("s_ipt")函数捕获百度输入框。

    2.3.CSS 定位

    CSS(Cascading Style Sheets)是一种语言,它被用来描述 HTML 和 XML 文档的表现。
    CSS 使用选择器来为页面元素绑定属性。这些选择器可以被 selenium 用作另外的定位策略。
    CSS 的比较灵活可以选择控件的任意属性,上面的例子中:
    find_element_by_css_selector("#kw"),通过 find_element_by_css_selector( )函数,选择取百度输入框的 id 属性来定义
    也可以取 name 属性,<a href="http://news.baidu.com" name="tj_news">新 闻</a>
    driver.find_element_by_css_selector("a[name="tj_news"]").click()
    可以取 title 属性,<a onclick="queryTab(this);" mon="col=502&pn=0" title="web"
    href="http://www.baidu.com/">网页</a>
    driver.find_element_by_css_selector("a[title="web"]").click()

    2.4 XPath 定位

    XPath 是一种在 XML 文档中定位元素的语言。因为 HTML 可以看做 XML 的一种实现,所以 selenium 用户可是使用这种强大语言在 web 应用中定位元素。
    XPath 扩展了上面 id 和 name 定位方式,提供了很多种可能性,比如定位页面上的第三个多选框。
    xpath:attributer (属性)
    driver.find_element_by_xpath("//input[@id='kw']").send_keys("selenium")
    #input 标签下 id =kw 的元素
    xpath:idRelative (id 相关性)
    driver.find_element_by_xpath("//div[@id='fm']/form/span/input").send_keys("s
    elenium")
    #在/form/span/input 层级标签下有个 div 标签的 id=fm 的元素
    driver.find_element_by_xpath("//tr[@id='check']/td[2]").click()
    # id 为'check' 的 tr ,定位它里面的第2个 td
    xpath:position (位置)
    driver.find_element_by_xpath("//input").send_keys("selenium")
    driver.find_element_by_xpath("//tr[7]/td[2]").click()
    #第7个 tr 里面的第2个 td
    xpath: href (水平参考)
    driver.find_element_by_xpath("//a[contains(text(),'网页')]").click()
    #在 a 标签下有个文本(text)包含(contains)'网页' 的元素
    xpath:link
    driver.find_element_by_xpath("//a[@href='http://www.baidu.com/']").click()
    #有个叫 a 的标签,他有个链接 href='http://www.baidu.com/ 的元素

    2.5 link 定位

    有时候不是一个输入框也不是一个按钮,而是一个文字链接,我们可以通过 link

    #coding=utf-8
    from selenium import webdriver
    browser = webdriver.Firefox()
    browser.get("http://www.baidu.com")
    browser.find_element_by_link_text("贴 吧").click()
    browser.quit()

    一般一个页面上不会出现相同的文件链接,通过文字链接来定位也是一种简单有效的定位方式。

    2.6 Partial link text 定位

    通过部分链接定位,这个有时候也会用到,我还没有想到很好的用处。拿上面的例子,我可以只用链接的一部分文字进行匹配:
    browser.find_element_by_partial_link_text("贴").click()
    #通过 find_element_by_partial_link_text() 函数,我只用了“贴”字,脚本一样找到了"贴 吧" 的链接

    3、添加等待时间

    有时候为了保证脚本运行的稳定性,需要脚本中添加等待时间。

    3.1 、添加休眠

    添加休眠非常简单,我们需要引入 time 包,就可以在脚本中自由的添加休眠时间了。

    # coding = utf-8
    from selenium import webdriver
    import time #调入 time 函数
    browser = webdriver.Firefox()
    browser.get("http://www.baidu.com")
    time.sleep(0.3) #休眠0.3秒
    browser.find_element_by_id("kw").send_keys("selenium")
    browser.find_element_by_id("su").click()
    time.sleep(3) # 休眠3秒
    browser.quit()
    

    3.2 、智能等待

    通过添加 implicitly_wait() 方法就可以方便的实现智能等待;implicitly_wait(30)的用法应该比 time.sleep() 更智能,后者只能选择一个固定的时间的等待,前者可以
    在一个时间范围内智能的等待。
    文档解释:
    selenium.webdriver.remote.webdriver.implicitly_wait(time_to_wait)
    隐式地等待一个无素被发现或一个命令完成;这个方法每次会话只需要调用一次
    time_to_wait: 等待时间
    用法:
    browser.implicitly_wait(30)

    # coding = utf-8
    from selenium import webdriver
    import time #调入 time 函数
    browser = webdriver.Firefox()
    browser.get("http://www.baidu.com")
    browser.implicitly_wait(30) #智能等待30秒
    browser.find_element_by_id("kw").send_keys("selenium")
    browser.find_element_by_id("su").click()
    browser.quit()
    

    4、打印信息

    很多时间我们不可能盯着脚本执行,我们需要一些打印信息来证明脚本运行是否正确:

    4.1 、打印 tile把刚才访问页面的 title 打印出来。

    coding = utf-8
    from selenium import webdriver
    driver = webdriver.Chrome()
    driver.get('http://www.baidu.com')
    print driver.title # 把页面 title 打印出来
    driver.quit()
    

     虽然我没看到脚本的执行过程,但我在执行结果里看到了:百度一下,你就知道

    说明页面正确被我打开了。

  • 相关阅读:
    HTML CSS 特殊字符表
    vscode代码统计——Vscode counter
    js数组方法整理
    CSS-界面滚动时不显示滚动条
    Vue Loader 作用域CSS(scoped)——/deep/ 深入组件选择器
    PHP模板引擎,Smarty定义
    mysql触发器trigger 实例详解
    mysql关于数据库表的水平拆分和垂直拆分
    关于数据库表的水平拆分和垂直拆分
    使用Merge存储引擎实现MySQL分表
  • 原文地址:https://www.cnblogs.com/101718qiong/p/7390718.html
Copyright © 2011-2022 走看看