python - Scrapy、Selenium、jQuery Dropdown 与具有 style="display: none;" 的选择标签的行为不一致
问题描述
我正在尝试在此页面上设置下拉菜单:
第一个下拉列表和第四个下拉列表非常相似(品牌和国家/地区)。这是我用于获取品牌 (oem) 和国家/地区的代码:
oem = Select(wd.find_element_by_css_selector("#alBrandsList"))
oem.select_by_visible_text("Acer")
countries = Select(wd.find_element_by_css_selector("#alCountriesList"))
countries.select_by_visible_text("Albania")
该下拉列表在技术上是隐藏的,但它似乎适用于设备/oem 下拉列表。对于国家下拉列表,它表示内容不可见(它是)。这是它从中提取的 HTML 代码:
<select class="pretty-dropdown" datatosent="brand" id="alBrandsList" name="alBrandsList" selectorid="alPhoneModelsList" target="/AdvanceLookup/GetPhoneModels/" style="display: none;">
...
</select>
<button type="button" class="ui-multiselect ui-widget ui-state-default ui-corner-all" aria-haspopup="true" style="width: 232px;">
<span class="ui-icon ui-icon-triangle-2-n-s"></span>
<span>Please select brand(s)</span>
</button>
<select class="pretty-dropdown" datatosent="country" id="alCountriesList" name="alCountriesList" selectorid="alCarriersList" target="/AdvanceLookup/GetCarriers/" style="display: none;">
...
</select>
<button type="button" class="ui-multiselect ui-widget ui-state-default ui-corner-all" aria-haspopup="true" style="width: 232px;">
<span class="ui-icon ui-icon-triangle-2-n-s"></span>
<span>Please select country</span>
</button>
知道为什么它适用于第一个而不适用于第二个吗?
解决方案
由于<select>
页面https://willmyphonework.net/AdvanceLookup上第一个和第四个下拉列表的标签都具有style="display: none;
您不能使用Select
Class的属性。相反,您需要诱导WebDriverWait并且element_to_be_clickable()
您可以使用以下Locator Strategies:
代码块:
from selenium import webdriver from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.common.by import By from selenium.webdriver.support import expected_conditions as EC driver.get('https://willmyphonework.net/AdvanceLookup') WebDriverWait(driver, 10).until(EC.element_to_be_clickable((By.XPATH, "//button[@class='ui-multiselect ui-widget ui-state-default ui-corner-all']//span[text()='Please select brand(s)']"))).click() WebDriverWait(driver, 10).until(EC.element_to_be_clickable((By.XPATH, "//ul[@class='ui-multiselect-checkboxes ui-helper-reset']//li/label/input[@title='Acer']"))).click() driver.find_element_by_xpath("//ul[@class='ui-helper-reset']//li/a/span[@class='ui-icon ui-icon-circle-close']").click() WebDriverWait(driver, 10).until(EC.element_to_be_clickable((By.XPATH, "//button[@class='ui-multiselect ui-widget ui-state-default ui-corner-all']//span[text()='Please select country']"))).click() WebDriverWait(driver, 10).until(EC.element_to_be_clickable((By.XPATH, "//ul[@class='ui-multiselect-checkboxes ui-helper-reset']//li/label/input[@title='Albania']"))).click() driver.find_element_by_xpath("//div[@class='ui-multiselect-menu ui-widget ui-widget-content ui-corner-all']//following::ul[6]//a[@class='ui-multiselect-close']/span[@class='ui-icon ui-icon-circle-close']").click()
浏览器快照:
推荐阅读
- css - Angular CSS 视图应用于子级
- apache-spark - 为什么我们需要 hadoop 或 java 在集群模式下进行 spark-submit (k8s Spark CRD)
- r - 使用 jtools 包绘制带有偏移量的模型预测
- github - 使用 GitHub Actions 容器映像构建的输出来提供标签值
- javascript - 如何使用 Vuejs 设置变量
- heroku - 无法在 Login.interactive 处读取未定义的属性“id”
- reactjs - 触发具有 React 状态的 aria-live 区域
- javascript - 如何遍历多级 JSON 对象并从其中一个键和值创建一个新的 Javascript 对象
- python - 如何在 Python 的 Pandas 数据框中的列中删除符号“/”之后的每个值?
- javascript - Mongoose - find() 在没有传递参数时不返回任何内容,但在传递参数时返回数据