zoukankan      html  css  js  c++  java
  • Selenium的定位元素

    1.浏览器操作

    # 刷新
    driver.refresh()
     
    # 前进
    driver.forward()
     
    # 后退
    driver.back()

    2.获取标签元素

    # 通过ID定位目标元素

    driver.find_element_by_id('i1')
     
    # 通过className定位目标元素
    driver.find_element_by_class_name('c1')
     
    # 通过name属性定位目标元素
    driver.find_element_by_name('n1')
     
    # 通过Xpath定位目标元素
    driver.find_element_by_xpath('//*[@id="i1"]')
     
    # 通过css Selector定位目标元素
    driver.find_element_by_css_selector('#i1')
     
    # 通过标签名称定位(注:在一个页面中,标签一定会重复,所以不用这个来进行定位)
    driver.find_element_by_tag_name('input')
     
    # 通过标签中的文本查找元素
    driver.find_element_by_link_text('登录')
     
    # 通过标签中文本的模糊匹配查找
    driver.find_elements_by_partial_link_text('录')
    3.Cookie操作
    # 根据cookieKey,获取cookie信息
    cookie = driver.get_cookie('cookieKey')
     
    # 获取所有cookie信息
    cookies = driver.get_cookies()
     
    # 添加cookie,严格按照格式添加,cookie的key为name,value为value
    driver.add_cookie({'name':'tmp','value':'123123123'})
     
    # 删除所有cookie信息
    driver.delete_all_cookies()
     
    # 根据cookieKey删除对应cookie
    driver.delete_cookie('UiCode')
    4.窗口操作
    # 获取当前浏览器的大小
    driver.get_window_size()
     
    # 通过像素设置浏览器的大小
    driver.set_window_size('width','height')
     
    # 获取当前窗口针对于Windows的位置的坐标x,y
    driver.get_window_position()
     
    # 设置当前窗口针对Windows的位置,x,y
    driver.set_window_position(20,20)
     
    # 最大化当前窗口,不需要传参
    driver.maximize_window()
     
    # 返回当前操作的浏览器句柄
    driver.current_window_handle
     
    # 返回所有打开server的浏览器句柄
    driver.window_handles
    5.截取当前页面
    # 获取当前页面的二进制图片数据,需要自己去写入文件
    driver.get_screenshot_as_png()
     # as_png的上层封装,只需要传入图片名称自动写成图片
    driver.get_screenshot_as_file('fileName.png')
    6.执行JavaScript语句
    # 执行JavaScript语句
    driver.execute_script('JavaScript Commond')
     
    # 例:
    # 通过js来操作滚动条
    # 参数1:x  参数2: y
    window.scrollTo(100,400);
    6.关闭与退出
    # 当开启多个时,关闭当前页面
    driver.close()
     
    # 退出并关闭所有页面驱动
    driver.quit()
    7.其他
    # 返回页面源码
    driver.page_source
     
    # 返回tag标题
    driver.title
     
    # 返回当前Url
    driver.current_url
     
    # 获取浏览器名称 如:chrome
    driver.name
    8.ElementApi接口

    # 根据标签属性名称,获取属性value

    element.get_attribute('style')
     
    # 向输入框输入字符串 如果input的type为file类型 可以输入文件绝对路径上传文件
    element.send_keys()
     
    # 清除文本内容
    element.clear()
     
    # 鼠标左键点击操作
    element.click()
     
    # 通过属性名称获取属性
    element.get_property('id')
     
    # 返回元素是否可见 True or False
    element.is_displayed()
     
    # 返回元素是否被选中 True or False
    element.is_selected()
     
    # 返回标签元素的名字
    element.tag_name
     
    # 获取当前标签的宽和高
    element.size
     
    # 获取元素的文本内容
    element.text
     
    # 模仿回车按钮 提交数据
    element.submit()
     
    # 获取当前元素的坐标
    element.location
     
    # 截取图片
    element.screenshot()
     
    8.常见异常
    oSuchElementException:没有找到元素
     
    NoSuchFrameException:没有找到iframe
     
    NoSuchWindowException:没找到窗口句柄handle
     
    NoSuchAttributeException:属性错误
     
    NoAlertPresentException:没找到alert弹出框
     
    ElmentNotVisibleException:元素不可见
     
    ElementNotSelectableException:元素没有被选中
     
    TimeoutException:查找元素超时
  • 相关阅读:
    Oracle 系统表大全
    oracle高效分页存储过程(百万数据级)
    PowerDesigner中name与comment互相转换脚本
    一些web开发中常用的、做成cs文件的js代码
    Ado.net Entity Model 模板出错的修复
    做ssl通道时遇到“请求被中止: 未能创建 SSL/TLS 安全通道”问题的解决方法
    SQLSERVER 2008空间数据库学习(一)
    jquery的全选、全不选、反选例子
    win7 64位下使用oracle ado.net entity framework
    半角/全角互换的代码
  • 原文地址:https://www.cnblogs.com/xuzhongtao/p/9613721.html
Copyright © 2011-2022 走看看