zoukankan      html  css  js  c++  java
  • selenium select下拉选择框定位处理的两种方式

    一、前言

         总结一下python+selenium select下拉选择框定位处理的两种方式,以备后续使用时查询;

    二、直接定位(XPath)

    使用Firebug找到需要定位到的元素,直接右键复制XPath,使用find_element_by_xpath定位;

    driver = webdriver.Firefox()
    driver.get("https://www.baidu.com/")
    driver.find_element_by_xpath().click()


    三、间接定位(Select模块)

    页面HTML源码如下所示:

    <select id="nr" name="NR">
    <option value="10" selected="">每页显示10条</option>
    <option value="20">每页显示20条</option>
    <option value="50">每页显示50条</option>
    </select>

    python+selenium 代码如下:

    # coding:utf-8
    from selenium import webdriver
    from selenium.webdriver.common.action_chains import ActionChains
    from selenium.webdriver.support.select import Select
    import time
    
    driver = webdriver.Chrome()
    driver.get("https://www.baidu.com/")
    driver.implicitly_wait(20)
    
    mouse = driver.find_element_by_link_text("设置")
    ActionChains(driver).move_to_element(mouse).perform()
    driver.find_element_by_link_text("搜索设置").click()
    time.sleep(2)
    # 实例化select
    s = Select(driver.find_element_by_id("nr"))
    # 定位选项
    s.select_by_value("20") # 选择value="20"的项:通过value属性
    time.sleep(2) #为了明显的看出变化
    s.select_by_index(0) # 选择第一项选项:通过选项的顺序选择,第一个为 0
    time.sleep(2) #为了明显的看出变化
    s.select_by_visible_text("每页显示50条") # 选择text="每页显示50条"的值,即在下拉时我们可以看到的文本


    四、总结

    Select提供了三种选择方法:

    select_by_index(index) ——通过选项的顺序,第一个为 0
    select_by_value(value) ——通过value属性
    select_by_visible_text(text) ——通过选项可见文本

    Select提供了四种方法取消选择:

    deselect_by_index(index)
    deselect_by_value(value)
    deselect_by_visible_text(text)
    deselect_all()

    Select提供了三个属性方法提供信息:

    options ——提供所有的选项的列表,其中都是选项的WebElement元素
    all_selected_options ——提供所有被选中的选项的列表,其中也均为选项的WebElement元素
    first_selected_option ——提供第一个被选中的选项,也是下拉框的默认值

    通过Select提供的方法和属性,我们可以对标准select下拉框进行任何操作,但是对于非select标签的伪下拉框,需要使用XPath定位;

  • 相关阅读:
    微积分
    Docker实战
    使用 Docker 建立 Mysql 集群
    Adaptive Query Optimization in Oracle Database 12c (12.1 and 12.2)
    open()在Linux内核的实现(5)-符号链接目录项的处理
    Red Hat Enterprise Linux上配置SQL Server Always On Availability Group
    Linux进程(作业)的查看和杀死 牛
    为Go语言GC正名-20秒到100微妙的演变史
    汇编语言---GCC内联汇编
    ActiveReports 报表应用教程 (15)---报表换肤
  • 原文地址:https://www.cnblogs.com/nini0806/p/13411204.html
Copyright © 2011-2022 走看看