gpt4 book ai didi

python - 如何优雅地处理 selenium 中的 NoSuchElementElement 异常?

转载 作者:行者123 更新时间:2023-12-04 17:18:39 25 4
gpt4 key购买 nike

我有大约 20 个元素要通过 xpath 查找。我正在使用这个。

e1 = element.find_element_by_xpath('.//div[contains(@class, "myclass")]').text

当找不到元素时,抛出NoSuchElementException
一种解决方案是使用:find_elements_by_xpath

e1 = element.find_elements_by_xpath('.//div[contains(@class, "myclass")]')
# Then check for length
if len(e1) > 0:
text1 = e1[0].text

这是一个元素的 3 行代码。
如果我同时使用tryexcept,那么会有60行代码完成这样一项微不足道的任务。

如何优雅地处理这个问题?另外,有什么方法可以直接从 xpath 中找到 text 而不是像这样执行 element.text :

# This should return text inside of that element
text = element.find_element_by_xpath('.//div[contains(@class, "myclass")]/text()')

最佳答案

最简单的最佳实践方式,according to the Selenium docs ,要做到这一点就是按照您的建议使用 .find_elements() 将其包装在一个函数中以使其更易于重用,保持代码干燥,并使代码更易于阅读。

与其将定位器仅限于 XPath,不如在您的方法中使用 By。

from selenium.webdriver.common.by import By

def get_text(element, locator):
elements = element.find_elements(locator)
if len(elements) > 0:
return elements[0].text
return ""

注意:此处返回“”(空字符串)而不是None。如果在找不到时返回 None,则在对返回值执行某些操作时必须检查 None,否则会出现异常。

然后你就这样调用它

e1 = get_text(element, (By.XPATH, './/div[contains(@class, "myclass")]'))

或者更好的是,使用 CSS 选择器,因为它速度更快、支持更好,并且在这种情况下不太可能给您带来意外的元素。

e1 = get_text(element, (By.CSS_SELECTOR, "div.myclass"))

此外,您不能在浏览器的 XPath 中使用 /text(),因为浏览器仅支持 XPath 1.0,而 /text() 是更高版本.

关于python - 如何优雅地处理 selenium 中的 NoSuchElementElement 异常?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67626747/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com