在 Python 中对正则表达式执行 WebDriverWait() 或类似检查

rwb*_*yrd 3 python regex selenium webdriver selenium-webdriver

我希望能够执行类似于 a 的操作WebDriverWait(),即:

WebDriverWait(driver, 60).until(
    expected_conditions.text_to_be_present_in_element((By.XPATH, "//tr[5]/td[11]/div"), "1.000000")
)
Run Code Online (Sandbox Code Playgroud)

...对于正则表达式,它在失败之前等待指定的时间。我知道我可以做一些事情,比如……

assert re.search(r"[0,1]{1}.[0-9]{6}", driver.find_element_by_xpath("//tr[5]/td[11]/div").text)
Run Code Online (Sandbox Code Playgroud)

...或者我可以在上面的示例中将搜索替换为匹配。此方法的问题是,如果对象.. (1) 尚未加载或.. (2) 仍在更改为预期内容的过程中,它将失败。我可以做类似的事情...

for x in range (1,60):
    try:
        assert re.search(r"[0,1]{1}.[0-9]{6}", driver.find_element_by_xpath("//tr[5]/td[11]/div").text)
    except AssertionError:
        if x < 60:
            time.sleep(1)
        else:
            raise AssertionError
Run Code Online (Sandbox Code Playgroud)

...它每秒检查 60 秒,以查看断言语句的计算结果是否为 true。这可以适合模块或类。我想知道是否有一个更优雅的解决方案,在 Python 中用于 Selenium WebDriver,来处理我不知道的这个问题。

ale*_*cxe 7

如果您研究一下什么是“预期条件”,您会发现很容易制作自定义条件

import re

from selenium.webdriver.support.expected_conditions import _find_element


class text_match(object):
    def __init__(self, locator, regexp):
        self.locator = locator
        self.regexp = regexp

    def __call__(self, driver):
        element_text = _find_element(driver, self.locator).text
        return re.search(self.regexp, element_text)
Run Code Online (Sandbox Code Playgroud)

用法:

WebDriverWait(driver, 60).until(
    text_match((By.XPATH, "//tr[5]/td[11]/div"), r"[0,1]{1}.[0-9]{6}")
)
Run Code Online (Sandbox Code Playgroud)