加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

javascript – 我可以使用Python和Selenium的正则表达式找到一

发布时间:2020-12-14 23:11:38 所属栏目:资源 来源:网络整理
导读:我需要单击下拉列表并单击其中的隐藏元素. html将由javascript生成,我不会知道id或类名,但我知道它会有一个短语.我可以通过正则表达式查找和元素然后用硒点击它吗? 最佳答案 您不能简单地使用内置的selenium webdriver定位器进行基于正则表达式的搜索,但是

我需要单击下拉列表并单击其中的隐藏元素. html将由javascript生成,我不会知道id或类名,但我知道它会有一个短语.我可以通过正则表达式查找和元素然后用硒点击它吗?

最佳答案
您不能简单地使用内置的selenium webdriver定位器进行基于正则表达式的搜索,但是您可以使用多种方法来帮助您:

> contains()starts-with() XPath函数:

//div[contains(.,"Desired text")]
//div[starts-with(.,"Desired text")]

> preceding,preceding-sibling,followingfollowing-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)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读