python - 如何使用 Selenium 和 Python 从 html 选择下拉列表中选择没有任何 ID 属性的选项

标签 python selenium xpath css-selectors html-select

我正在尝试使用 Selenium Select 方法从下拉菜单中选择一个值,但我无法正确找到正确的元素,如其他 Stackoverflow 帖子中所示,因为我的元素缺少其他 Stackoverflow 帖子中的 ID。我尝试使用 Xpath、Class_Name 和 CSS_Selector 作为替代方案,但我不断收到错误“无法定位元素”。

这是 HTML:

<select class="lf-simpelselect lf-bottom-margin" data-bind="options: activiteitenOptions, value: activiteit, optionsText: 'Naam', optionsValue: 'Id', visible: toonActiviteiten()" style=""><option value="0bdae2c9-6ebc-4396-b3bb-0e587f9bbe86">Latin Jam</option><option value="c18aef82-be4d-4881-ae96-28aa72161c17">Kiddo Swing 6-8 jr</option><option value="8cbe6618-68cd-47f1-8a79-29db71498292">Ballet </option><option value="8d03eb2f-02ea-434d-8520-30b2f02e18f1">Pilates</option><option value="30358ec5-9751-4b13-8514-4db7b541c540">Gold 40+</option><option value="b811c4be-703b-4193-8f60-57bdb574a60a">Feminine</option><option value="2c6b4f41-6953-4347-99b9-70c33f48da07">City Jam</option><option value="696ba3a2-a453-4550-9cbe-7a00d46dfb14">Dojo</option><option value="fc8b9e43-401f-4e38-8d0b-8afba5f1226b">Power Jam</option><option value="7192a0d5-65b1-43a0-80d6-987b90cf505c">Dans Mix 9 - 12 jr</option><option value="820cf6c6-c9a6-4759-939e-988c646a69f7">Barre Workout</option><option value="e9bfd01d-b183-483a-b809-b2d9dd62354d">Latin House 18+</option><option value="505e1c62-9e68-4569-a7ef-b6566ff1b56d">Afro</option><option value="e4899faa-969e-4953-af1f-bc7eba080bec">Hip Hop</option><option value="796f9e98-f54c-486c-bc62-e6a2e74a5f45">Contemporary Flow </option><option value="88845fb5-e1ab-418d-ba3c-ed1131821835">Modern</option><option value="cb7fa275-b034-4f04-8265-ef747fe73179">Dancehall</option></select>

我尝试使用Select()更改值的代码如下:

url = "https://prd.mylogifit.com/logifitweb/genericwidgetbyid.html?a=Touchee&widgetId=73f1f696-5063-4fb7-9a8d-c588ef149eb4"

browser = webdriver.Chrome(executable_path='./chromedriver')
browser.get(url)

# Select lesson type (afro)
lesson_droplist = Select(browser.find_element(By.CLASS_NAME, 'lf-simpelselect lf-bottom-margin'))
lesson_droplist.select_by_value("Afro")

如何使用 Select 方法将下拉值从 Hip-Hop 更改为 Afro?

最佳答案

选择<option>文本为 Pilates,因为所需元素是动态 元素,您需要诱导 WebDriverWait对于 element_to_be_clickable()您可以使用以下任一 locator strategies :

  • 使用CSS_SELECTOR:

    driver.get("https://prd.mylogifit.com/logifitweb/genericwidgetbyid.html?a=Touchee&widgetId=73f1f696-5063-4fb7-9a8d-c588ef149eb4")
    Select(WebDriverWait(driver, 10).until(EC.element_to_be_clickable((By.CSS_SELECTOR, "select.lf-simpelselect.lf-bottom-margin[data-bind*='activiteitenOptions']")))).select_by_visible_text('Pilates')
    
  • 使用XPATH:

    driver.get("https://prd.mylogifit.com/logifitweb/genericwidgetbyid.html?a=Touchee&widgetId=73f1f696-5063-4fb7-9a8d-c588ef149eb4")
    Select(WebDriverWait(driver, 10).until(EC.element_to_be_clickable((By.XPATH, "//select[@class='lf-simpelselect lf-bottom-margin' and contains(@data-bind, 'activiteitenOptions')]")))).select_by_visible_text('Pilates')
    
  • 注意:您必须添加以下导入:

    from selenium.webdriver.support.ui import WebDriverWait
    from selenium.webdriver.common.by import By
    from selenium.webdriver.support import expected_conditions as EC
    from selenium.webdriver.support.ui import Select
    
  • 浏览器快照:

Pilates


引用文献

您可以在以下位置找到一些相关讨论:

关于python - 如何使用 Selenium 和 Python 从 html 选择下拉列表中选择没有任何 ID 属性的选项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/75346420/

相关文章:

java - 在带有 Selenium WebDriver 的 Java 中,如何仅在广告显示时使用 JavaScript 单击覆盖广告上的链接?

java - 如何使用 python(加上 java)在 selenium 中处理 Windows 身份验证弹出窗口

html - 子菜单单击不适用于操作

xpath - Wix 和 XPath : How to change version number with util:XmlFile when the path is not unique

php - 使用 Behat/Selenium 在特定的 DIV 中查找内容

python - 在 qtablewidget 中寻找信号

python - 通过 python 创建一个 vlan 并将其添加到网络命名空间

python - 上下文不打印 Django

python - 如何在 Django 中保存之前旋转图像?

python - 为什么 selenium/python/chromedriver 无法识别 chrome 开发者控制台中的有效 xpath?