我可以在python和Selenium中使用正则表达式找到元素吗?
我需要单击一个下拉列表,然后单击其中的隐藏元素。html将由javascript生成,但我不知道ID或类名,但我会知道其中会有一个短语。我可以通过正则表达式查找和元素,然后用硒单击它吗?
-
您不能简单地使用内置的硒webdriver定位器进行基于正则表达式的搜索,但是您可以通过多种操作来帮助您:
-
contains()
和starts-with()
XPath函数://div[contains(., "Desired text")]
//div[starts-with(., “Desired text”)]
-
preceding
,preceding-sibling
,following
和following-sibling
轴线,可以帮助你,如果你知道元素的新生成块的相对位置,你需要找到
还有 CSS选择器, 用于元素属性的部分匹配:
a[href*=desiredSubstring] # contains a[href^=desiredSubstring] # starts-with a[href$=desiredSubstring] # ends-with
而且,您总是可以找到比所需更多的元素,并稍后在Python中将其过滤掉,例如:
import re pattern = re.compile(r"^Some \w+ text.$") elements = driver.find_elements_by_css_selector("div.some_class") for element in elements: match = pattern.match(element.text) if match: print(element.text)
-