您的位置 首页 知识分享

Python For循环中元素定位失效:为什么在 Excel 参数化测试中,循环执行后定位元素失败,而调整浏览器调用位置后就能解决问题?

for循环中元素定位失效 在使用 python 中的 for 循环读取 excel 数据进行登录参数化测试时,…

Python For循环中元素定位失效:为什么在 Excel 参数化测试中,循环执行后定位元素失败,而调整浏览器调用位置后就能解决问题?

for循环中元素定位失效

在使用 python 中的 for 循环读取 excel 数据进行登录参数化测试时,开发者可能会遇到一个问题,即第一遍执行成功,而第二遍却报错,无法定位元素。

解决方案:在 for 循环外部调用浏览器

对于这个特定问题,解决方法是将浏览器的调用放在 for 循环的外部。修改后的测试代码示例如下:

立即学习“”;

import unittest import time import xlrd from selenium import webdriver  def open_excel(file):     try:         data = xlrd.open_workbook(file)         return data     except Exception as e:         print(str(e))  def excel_table_byindex(file, colnameindex=0, by_index=0):     data = open_excel(file)     table = data.sheets()[by_index]     nrows = table.nrows     colnames = table.row_values(colnameindex)     list = []     for rownum in range(1, nrows):         row = table.row_values(rownum)         if row:             app = {}             for i in range(len(colnames)):                 app[colnames[i]] = row[i]             list.append(app)     return list  class login(unittest.TestCase):      def setUp(self):         self.driver = webdriver.Firefox()         self.driver.maximize_window()         self.driver.implicitly_wait(10)         self.driver.get("https://passport.meituan.com/account/unitivelogin?service=www&amp;continue=http%3A%2F%2Fwww.meituan.com%2Faccount%2Fsettoken%3Fcontinue%3Dhttps%253A%252F%252Fwww.meituan.com%252F")         time.sleep(5)      def test(self):         tabls = excel_table_byindex(file='./data/meit.xlsx')         print(tabls)         if (len(tabls) <p>通过将浏览器的初始化和退出操作移动到 for 循环之外,我们可以确保每次迭代都使用一个新的浏览器实例。这样,就不会出现元素定位失效的问题。</p>
登录后复制

以上就是Python For循环中元素定位失效:为什么在 Excel 参数化测试中,循环执行后定位元素失败,而调整浏览器调用位置后就能解决问题?的详细内容,更多请关注php中文网其它相关文章!

本文来自网络,不代表甲倪知识立场,转载请注明出处:http://www.spjiani.cn/wp/4280.html

作者: nijia

发表评论

您的电子邮箱地址不会被公开。

联系我们

联系我们

0898-88881688

在线咨询: QQ交谈

邮箱: email@wangzhan.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部