是否可以存储selenium对象?(Python)

是否可以存储selenium对象?(Python),python,selenium,automation,Python,Selenium,Automation,我试图捕获自动化程序中的错误,并将它们作为参数传递给另一个函数。 我的目标是存储这些在自动机过程中导致错误的selenium对象,并在主要功能完成后处理它们 目前,我正在将错误详细信息发送到csv文件: def send_keys_dropdown(self,url,csv_name): elements = bot.find_elements_by_xpath("//a[@data-tag='globalize']") for elem in elements:

我试图捕获自动化程序中的错误,并将它们作为参数传递给另一个函数。 我的目标是存储这些在自动机过程中导致错误的selenium对象,并在主要功能完成后处理它们

目前,我正在将错误详细信息发送到csv文件:

def send_keys_dropdown(self,url,csv_name):
        elements = bot.find_elements_by_xpath("//a[@data-tag='globalize']")
        for elem in elements:
            class_of_element = elem.get_attribute("class")
            if class_of_element == 'CsLinkButton':
                try:
                   # Some actions here
                except (ElementNotInteractableException, ElementNotVisibleException) as e:
                    handle_errors(elem, url, e)
                    pass
如您所见,handle_errors()函数接受3个参数和:

    def handle_errors(self, elem, url, e):
        bot = self.bot
        with open('errors.csv', mode='w', newline='', encoding="utf-8") as csv_file:
            fieldnames = ['URL', 'Element', 'Error']
            writer = csv.DictWriter(csv_file, fieldnames=fieldnames)
            writer.writeheader()
            writer.writerow({ 'URL': url, 'Element': elem, 'Error':e })
        with open('errors.csv', 'rt',encoding='utf8') as csvfile:
            errors_list = csv.reader(csvfile, delimiter=',', quotechar='"')
            errors_list = list(errors_list)
            bot.get(url)
            time.sleep(3)

此函数将从csv获取url,并转到导致错误的页面,下一个应该是查找导致错误的元素。但是,我不知道如何存储这些selenium对象

我试图直接传递元素(不写csv),但它仍然不起作用


谢谢你的帮助

我假设您希望在主脚本完成后重试/调查错误。在这种情况下,不可能直接保存WebElement对象以供将来使用,因为该元素的所有上下文都已丢失

您可以将定位器保存到csv,或者,如@pcalkins所建议的,如果您想稍后进行调查,可以保存HTML的内容

此外,我建议您将部件读取错误从
handle_error()
中拆分出来,并将其移动到要重试/调查的位置

    def send_keys_dropdown(self,url,csv_name):
        by, locator = By.XPATH, "//a[@data-tag='globalize']"
        elements = bot.find_elements_by_xpath("//a[@data-tag='globalize']")
        for elem in elements:
            class_of_element = elem.get_attribute("class")
            if class_of_element == 'CsLinkButton':
                try:
                   # Some actions here
                except (ElementNotInteractableException, ElementNotVisibleException) as e:
                    handle_errors(by, locator, url, e)
                    pass

    def handle_errors(self, by, locator, url, e):
        bot = self.bot
        with open('errors.csv', mode='w', newline='', encoding="utf-8") as csv_file:
            fieldnames = ['URL', 'By', 'Locator', 'Error']
            writer = csv.DictWriter(csv_file, fieldnames=fieldnames)
            writer.writeheader()
            writer.writerow({ 'URL': url, 'By': by, 'Locator': locator, 'Error':e })

    def retry_errors(self):
        bot = self.bot
        with open('errors.csv', 'rt',encoding='utf8') as csvfile:
            errors_list = csv.reader(csvfile, delimiter=',', quotechar='"')
            errors_list = list(errors_list)
            for error in errors_list:
              # actions you want to retry

使用element.getAttribute('innerHTML')和element.getAttribute('outerHTML')非常好的解决方案,非常感谢!