zoukankan      html  css  js  c++  java
  • selenium常用方法

     

    一、常用库导入

    1.from selenium import webdriver  导入webdriver模块

    2.from selenium.webdriver import ActionChains  导入动作链类,动作链可以储存鼠标的动作,并一起执行

    3.from selenium.webdriver.common.key import Key  键盘操作使用的是Keys类,一般配合send_keys使用

    4.from selenium.webdriver.support.select import Select  下拉框的操作都交由Select类进行处理

    5.from selenium.webdriver.common.by import By

    from selenium.webdriver.support.ui import WebDriverWait

    from selenium.webdriver.support import expected_conditions as EC     显示等待使用的类

    二、基本操作

    1.浏览器相关操作

    创建浏览器对象  driver = webdriver.xxx()

    窗口最大化    maximize_window()

    获取浏览器尺寸  get_window_size()

    设置浏览器尺寸  set_window_size()

    获取浏览器位置  get_window_position()

    设置浏览器位置  set_window_position(x,y)

    关闭当前标签/窗口 close()

    关闭所有标签/窗口  quit()

    2.页面相关操作

    请求某个url      driver.get(url)

    刷新页面操作     refresh()

    回退到之前的页面   back()

    前进到之后的页面   forward()

    获取当前访问页面url  current_url

    获取当前浏览器标题  title

    保存图片       get_screenshot_as_png()/get_screenshot_as_file(file)

    网页源码       page_source

    3.页面元素的定位(八种定位方式)

    id定位       driver.find_element_by_id(value)

    name属性值定位  driver.find_element_by_name(value)

    类名定位       driver.find_element_by_class_name(value)

    标签名定位      driver.find_element_by_tag_name(value)

    链接文本定位     driver.find_element_by_link_text(value)

    部分链接文本    driver.find_element_by_partial_link_text(value)

    xpath路径表达式  driver.find_element_by_xpath(value)

    css选择器     driver.find_element_by_css_selector(value)

    4.元素的操作

    对元素的相关操作,一般要先获取到元素,再调用相关方法 element = driver.find_element_by_xxx(value)

    点击操作    element.click()

    清空输入框   element.clear()

    输入框输入数据 element.send_keys(data)

    获取文本内容(既开闭标签之间的内容)  element.text

    获取属性值(获取element元素的value属性的值)  element.get_attribute(value)

    5.鼠标和键盘操作

    鼠标操作需要导入类,见第一部分,然后创建对象ActionChains(driver),键盘操作导入类见第一部分

    鼠标右击

    el = driver.find_element_by_xxx(value)

    context_click(el)

    鼠标双击

    el = driver.find_element_by_xxx(value)

    ActionChains(driver).double_click(el).perform()

    鼠标悬停

    el = driver.find_element_by_xxx(value)

    ActionChains(driver).move_to_element(el).perform()

    常用键盘操作

    send_keys(Keys.BACK_SPACE) 删除键(BackSpace)

    send_keys(Keys.SPACE) 空格键(Space)

    send_keys(Keys.TAB) 制表键(Tab)

    send_keys(Keys.ESCAPE) 回退键(Esc)

    send_keys(Keys.ENTER) 回车键(Enter)

    send_keys(Keys.CONTROL,‘a’) 全选(Ctrl+A)

    send_keys(Keys.CONTROL,‘c’) 复制(Ctrl+C)

    send_keys(Keys.CONTROL,‘x’) 剪切(Ctrl+X)

    send_keys(Keys.CONTROL,‘v’) 粘贴(Ctrl+V)

    6.弹出框操作

    进入到弹出框中  driver.switch_to.alert()

    接收警告     accept()

    关闭警告     dismiss()

    发送文本到警告框 send_keys(data)

    7.下拉框操作

    将定位到的下拉框元素传入Select类中  selobj = Select(element)

    通过索引选择,index 索引从 0 开始  select_by_index()

    通过值选择(option标签的一个属性值)  select_by_value()

    通过文本选择(下拉框的值)  select_by_visible_text()

    查看所有已选  all_selected_options

    查看第一个已选  first_selected_option

    查看是否是多选  is_multiple

    查看选项元素列表  options

    取消选择   deselect_by_index() /deselect_by_value()/ deselect_by_visible_text()

    8.滚动条操作

    js = "window.scrollTo(x,y) " x为水平拖动距离,y为垂直拖动举例

    driver.execute_script(js)

    js= "var q=document.documentElement.scrollTop=n" n为从顶部往下移动滚动举例

    driver.execute_script(js)

    9.cookies操作

    获取所有cookies  get_cookies()

    获取key对应的值  get_cookie(key)

    设置cookies  add_cookie(cookie_dict)

    删除指定名称的cookie  delete_cookie(name)

    删除所有cookie  delete_all_cookies()

    10.多标签/多窗口、多表单/多框架切换

    多表单/多框架切换 

    直接使用id值切换进表单   driver.switch_to.frame(value)

    定位到表单元素,再切换进入

    el = driver.find_element_by_xxx(value)

    driver.switch_to.frame(el)

    跳回最外层的页面  driver.switch_to.default_content()

    跳回上层的页面  driver.switch_to.parent_frame()

    多标签/多窗口之间的切换

    获取所有窗口的句柄   handles = driver.window_handlers

    通过窗口的句柄进入的窗口  driver.switch_to.window(handles[n])

    原文:https://www.cnblogs.com/Maggie2019/p/11016250.html

    目前正在学习Python中,如果有什么不对的地方 希望广大朋友,指出错误指出,深表感谢
  • 相关阅读:
    mock 数据模拟
    利用css绘制三角形,半圆等形状
    页面底部固定
    Form Data格式传参
    element 页面显示效果及需要注意的点
    vue 组件加载顺序
    vue-router 导航钩子
    vue 总结
    前端开发的碎碎念
    值匹配的方式
  • 原文地址:https://www.cnblogs.com/shiguanggege/p/13141745.html
Copyright © 2011-2022 走看看