是否可以存储selenium对象?(Python)
我试图捕获自动化程序中的错误,并将它们作为参数传递给另一个函数。 我的目标是存储这些在自动机过程中导致错误的selenium对象,并在主要功能完成后处理它们 目前,我正在将错误详细信息发送到csv文件:是否可以存储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:
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')非常好的解决方案,非常感谢!