zoukankan      html  css  js  c++  java
  • web selenium 小笔记

    常用库导入

    from selenium import webdriver #导入webdriver模块

    from selenium.webdriver.common.by import By # XPATH 定位模块 

    from selenium.webdriver.remote.webdriver import WebElement #引入对象

    from selenium.webdriver.support import expected_conditions as EC #配合 WebDriverWait使用

    from selenium.webdriver.support.wait import WebDriverWait #显示式等待

    from selenium.webdriver.support.select import Select #下拉框操作由Select

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

    from selenium.webdriver.common.keys import Keys #键盘操作使用的Keys类,配合send_keys使用

    expected_conditions类提供的预期条件判断的方法

    title_is                            #判断当前页面的 title 是否完全等于(==)预期字符串,返回布尔值
    title_contains                         #判断当前页面的 title 是否包含预期字符串,返回布尔值
    presence_of_element_located                #判断某个元素是否被加到了 dom 树里,并不代表该元素一定可见
    visibility_of_element_located                  #判断元素是否可见(可见代表元素非隐藏,并且元素宽和高都不等于 0)
    visibility_of                       #同上一方法,只是上一方法参数为locator,这个方法参数是 定位后的元素
    presence_of_all_elements_located             #判断是否至少有 1 个元素存在于 dom 树中。举例:如果页面上有 n 个元素的 class 都是’wp’,那么只要有 1 个元素存在,这个方法就返回 True
    text_to_be_present_in_element               #判断某个元素中的 text 是否 包含 了预期的字符串
    text_to_be_present_in_element_value              #判断某个元素中的 value 属性是否包含 了预期的字符串
    frame_to_be_available_and_switch_to_it          #判断该 frame 是否可以 switch进去,如果可以的话,返回 True 并且 switch 进去,否则返回 False
    invisibility_of_element_located              #判断某个元素中是否不存在于dom树或不可见
    element_to_be_clickable                #判断某个元素中是否可见并且可点击
    staleness_of                      #等某个元素从 dom 树中移除,注意,这个方法也是返回 True或 False
    element_to_be_selected                #判断某个元素是否被选中了,一般用在下拉列表
    element_selection_state_to_be             #判断某个元素的选中状态是否符合预期
    element_located_selection_state_to_be         #跟上面的方法作用一样,只是上面的方法传入定位到的 element,而这个方法传入 locator
    alert_is_present                   #判断页面上是否存在 alert

    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#############
    将定位到的下拉框元素传入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])

  • 相关阅读:
    Ubuntu20安装docker
    ubuntu 下mysql 大小写问题
    Tensorflow-常见报错解决方案
    迁移学习(Transfer Learning)
    c#的托管代码和非托管代码的理解
    .net面试题升级版
    ADO.NET知识点
    支持“WeShopDb”上下文的模型已在数据库创建后发生更改。请考虑使用 Code First 迁移更新数据库
    .net 面试题
    6、zookeeper应用场景-分布式唯一ID
  • 原文地址:https://www.cnblogs.com/chevron123/p/12607829.html
Copyright © 2011-2022 走看看