zoukankan      html  css  js  c++  java
  • Selenium-核心WebDriver

    1、页面元素识别与定位

    页面元素由标签对组成
    标签有各种属性
    标签对之间可以有文本数据
    标签有层级关系

    Webdriver提供了8种元素定位方法,在python中对应的方法为:

    Id定位:find_element_by_id()
    Name定位: find_element_by_name()
    Tag定位: find_element_by_tag_name()
    Class定位: find_element_by_class_name()
    Link_text定位: find_element_by_link_text()
    Xpath定位: find_element_by_xpath()
    Css_selector定位: find_element_by_css_selector
    Link_text定位: find_element_by_link_text()
    Partial link定位:find_element_by_partial_link_text()
    Partial link定位是对link定位的一种补充,有些文字链接比较长,这个时候我们可以取部分文字进行定位,只要是可以唯一标识即可。比如find_element_by_partial_link_text(“首页”)

     2、Xpath定位

    XPath在XML文档中定位元素的语言。selenium 用户可是使用这种 强大语言在web应用中定位元素。
    Xpath定位 find_element_by_xpath()
    用Xpath定位百度输入框与百度搜索按钮
    1、绝对路径定位(主要用标签名的层级关系)
    Find_element_by_xpath(“/html/body/div/div[2]/div/div/div/form/span/input”)
    Find_element_by_xpath(“/html/body/div/div[2]/div/div/div/form/span[2]/input”)

    2、利用元素属性定位
    Find_element_by_xpath(“//input[@id=‘kw’]”)
    Find_element_by_xpath(“//input[@id=‘su’]”)
    //input 表示当前页面某个input标签,[@id=‘kw’]表示这个元素id是kw
    Find_element_by_xpath(“//*[@name=‘wd’]”)
    Find_element_by_xpath(“//*[@class=‘s_ipt’]”)
    如果不想指定标签名,可以用星号(*)代替
    元素的任何属性都可以使用,只要能唯一标识
    Find_element_by_xpath(“//input[@tupe=‘submit’]”)

    3、层级与属性结合(通过搜索框的父元素下面的子标签)
    find_element_by_xpath("//span[@class='bg s_ipt_wr quickdelete-wrap']/input")
    4、使用逻辑运算符(一个属性不能唯一区分一个元素,那么可以用逻辑运算符连接多个属性来查找)
    Find_element_by_xpath(“//input[@id=‘kw’and @class=‘s_ipt’ ]”)
    And表示满足俩个条件

    3、Css定位

    # 通过class定位
    driver.find_element_by_css_selector(".s_btn")
    # 通过id定位
    driver.find_element_by_css_selector("#kw")
    # 通过标签名定位
    driver.find_element_by_css_selector("input")
    # 通过标签层级关系定位(选择父元素为 span 的所有 input元素)
    driver.find_element_by_css_selector("span>input")
    # 通过属性定位
    driver.find_element_by_css_selector("[type='submit]")
    driver.find_element_by_css_selector("[name='kw]")
    # 组合定位
    driver.find_element_by_css_selector("form.fm>span>input.s_ipt")
    driver.find_element_by_css_selector("form#form>span>input#kw")

     4、浏览器基本操作

    # 控制浏览器窗口大小
    # 浏览器高400,宽200像素
    driver.set_window_size(400,200)
    # 浏览器最大化
    driver.maximize_window()
    # 控制浏览器后退、前进
    driver.back()
    driver.forward()
    # 模拟浏览器刷新
    driver.refresh()
    # 关闭当前窗口
    driver.close()
    # 退出驱动关闭所有窗口
    driver.quit()

    5、鼠标操作

    # 与鼠标操作相关方法是封装在ActionChains类中
    # 引入ActionChains类
    from selenium.webdriver import ActionChains
    # context_click():右击
    # double_click():双击
    # drag_and_drop():拖动
    # move_to_element():鼠标悬停
    # perform():执行ActionChains类中存储的行为
    above = driver.find_element_by_link_text("设置")
    # 对定位到的元素执行鼠标悬停操作
    ActionChains(driver).move_to_element(above).perform()

    6、键盘操作

    # send_keys(Keys.BACK_SPACE):删除键
    # send_keys(Keys.SPACE):空格键
    # send_keys(Keys.TAB):制表键
    # send_keys(Keys.ESCAPE):回退键
    # send_keys(Keys.ENTER):回车键
    # send_keys(Keys.CONTROL,'a'):全选
    # send_keys(Keys.CONTROL,'c'):复制
    # send_keys(Keys.CONTROL,'x'):剪切
    # send_keys(Keys.CONTROL,'v'):黏贴
    # send_keys(Keys.F1):键盘F1
    driver.find_element_by_id("kw").send_keys("ceshi")
    driver.find_element_by_id("kw").send_keys(Keys.CONTROL,'a')

    7、等待时间

    现实:当浏览器加载页面时,页面上的元素并不会同时被加载, 因此增加了定位元素的困难(ElementNotVisibleException错误)。
    WebDriver提供了2种类型的等待
    显示等待(WebDriverWait类):使WebDriver等待某个条件成立时继续执行,否则在达到最大时间长时抛出超出时间异常(TimeoutException)
    隐式等待(implicitly_wait):通过一定时长的等待页面上元素加载完成。如果超出了设置的时间长,元素还未被加载,则抛出异常NoSuchElementException

    显示等待(WebDriverWait类):使WebDriver等待某个条件成立时继续执行,否则在达到最大时间长时抛出超出时间异常(TimeoutException)
    具体格式WebDriver(driver,timeout,poll_frequency=0.5,ignored_exceptions=None)
    • Driver:浏览器驱动
    • Timeout:最长超时,默认以秒为单位
    • Poll_frequency:检测间隔的(步长)时间,默认为0.5s
    • Ignored_exceptions:超时后的异常信息,默认情况下抛出 NoSuchElementException
    • WebDriverWait一般与until()与until_not()方法配合使用。

    隐式等待(implicitly_wait):通过一定时长的等待页面上元素加载完成。如果超出了设置的时间长,元素还未被加载,则抛出异常NoSuchElementException
    implicitly_wait单位是秒,设置10秒,并不是一个固定的等待时间,不影响脚本的执行速度。其次会等待页面上的所有元素。如果第6s找到就继续执行,超过10秒没找到则抛出异常。

    8、文件上传

    文件上传操作也较常见,上传功能操作webdriver并没有提供对应的方法。
    上传过程一般要打开一个系统的window 窗口,从窗口选择本地文件添加(问题:如何操作 本地window 窗口)。 上传本地文件;只要定位上传按钮,通send_keys 添加本地文件路径就可以了。绝对路径和 相对路径都可。
    # 文件上传
    # 若上传的元素是<input type="file" name="file"> 类似这样的,可以直接将路径send_keys到该元素
    driver.get("file:///D:/BestTesting/pyStudy/%E8%A2%AB%E6%B5%8Bdemo/uploadfile.html").
    driver.find_element_by_name("file").send_keys("C:\UsersAdministratorPictureskatyperry.png")

    9、表单处理

    frame/iframe嵌 套,webdriver 只能在一个页面 上对元素进行定位。
    switch_to.frame()方法进行切换。

    # 表单切换
    driver.get("file:///D:/BestTesting/pyStudy/%E8%A2%AB%E6%B5%8Bdemo/iframe.html")
    iframe = driver.find_element_by_id("iname")
    driver.switch_to.frame(iframe)
    driver.find_element_by_id("sb_form_q").send_keys("selenium")
    driver.find_element_by_id("sb_form_go").click()
    # 跳到iframe上一级driver.switch_to.parent_frame()
    driver.switch_to.parent_frame()
    # 跳到最外层的页面driver.switch_to.default_content()
    # driver.switch_to.default_content()
    driver.find_element_by_link_text("baidu").click()

    10、警告框

    在WebDriver中处理javascript所生成的alert、confirm、prompt十分简单,具体方法是使用switch_to.alert方法。
    alert = driver.switch_to.alert
    alert.accept() # 相当于点击确定
    alert.dismiss() # 相当于点击取消
    alert.text #获取弹出框里的文
    driver.switch_to_alert()
    driver.switch_to.alert
     selenium3.7.0中switch_to_alert()方法虽然被“画了横杠”,但是可以正常使用!

    11、下拉框处理

    # 导入select类
    from selenium.webdriver.support.select import Select
    # select_by_value()通过value值定位下拉框选项
    # select_by_visible_text()通过text值定位下拉选项
    # select_by_index()通过下拉选项索引来定位。0,1
    # 定位到下拉框
    driver.get("file:///D:/BestTesting/pyStudy/被测demo/select.html")
    sel =driver.find_element_by_name("select")
    Select(sel).select_by_value("1")
    # Select(sel).select_by_visible_text("苹果")
    # Select(sel).select_by_index("1")

    12、窗口截图

    # 窗口截图
    driver.get("http://www.baidu.com")
    # 截取当前窗口,指定图片保存位置
    driver.save_screenshot("C:\Users\Administrator\Pictures\test.png")

    13、操作cookies

     14、调用JS操作滚动条

  • 相关阅读:
    MongoDB安装与启动
    Mac node.js express-generator脚手架安装
    AJAX状态值与状态码
    博客园 Markdown编辑器简要教程
    高效、可维护、组件化的CSS
    如何在mac上运行vue项目
    前端chrome调试
    Light of future-冲刺集合
    团队作业第六次—事后诸葛亮
    Light of future-冲刺总结
  • 原文地址:https://www.cnblogs.com/katyhudson/p/12463118.html
Copyright © 2011-2022 走看看