• 12
  • 13
分享
  • 隔壁小哥涨薪的selenium自动化测试技巧——软件测试圈
  • 恬恬圈 2021-01-14 13:36:58 字数 6013 阅读 1576 收藏 13

selenium 中隐藏元素如何定位?

       面试题:selenium 中隐藏元素如何定位?这个是很多面试官喜欢问的一个题, 如果单纯的定位的话,隐藏元素和普通不隐藏元素定位没啥区别,用正常定位方 法就行了

       但是很多面试官自己都搞不清楚啥叫定位,啥叫操作元素(如 click,clear,send_keys)

隐藏元素

       面试 web 自动化必然会问到 selenium,问 selenium 相关的问题定位是最基本的, 也是自动化的根本,所以面试离不开元素定位问题。 之前看到招聘要求里面说“只会复制粘贴 xpath 的就不要投简历了”,说明面试 官对求职者的自动化能力要求不能停留在复制粘贴上。 还是那句话,想学自动化的话,需牢记:录制穷三代,复制毁一生!

1.如何判断一个页面上元素是否存在?

       这个可以说是被问烂的题了,判断元素存在方法有三种:

        方法一,用 try…except…

def is_element_exsist(driver, locator): ‘’’

       判断元素是否存在,存在返回 True,不存返回 False

:param locator: locator 为元组类型,如("id", "yoyo")
:return: bool 值,True or False '''
try:
driver.find_element(*locator) return True
except Exception as msg:
print("元素%s 找不到:%s" % (locator, msg)) return False
if   name== '  main  ':
loc1 = ("id", "yoyo")# 元素 1 print(is_element_exsist(driver, loc1))

       方法二:用 elements 定义一组元素方法

def is_element_exsist1(driver, locator): ‘’’

       判断元素是否存在,存在返回 True,不存返回 False

:param locator: locator 为元组类型,如("id", "yoyo")
:return: bool 值,True or False '''
eles = driver.find_elements(*locator) if len(eles) < 1:
return False else:
return True
if   name== '  main  ':
loc1 = ("id", "yoyo")# 元素 1 print(is_element_exsist1(driver, loc1))

       (强烈推荐!)方法三:结合 WebDriverWait 和 expected_conditions 判断 from selenium import webdriver

from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.ui import WebDriverWait def is_element_exsist2(driver, locator):
‘’’

       结合 WebDriverWait 和 expected_conditions 判断元素是否存在, 每间隔 1 秒判断一次,30s 超时,存在返回 True,不存返回 False

:param locator: locator 为元组类型,如("id", "yoyo")
:return: bool 值,True or False '''
try:
WebDriverWait(driver, 30, 1).until(EC.presence_of_element_located(locator))
return True except:
return False
if   name== '  main  ':
loc1 = ("id", "cemaxueyuan")# 元素 1 print(is_element_exsist2(driver, loc1))

2.如何提高脚本的稳定性

       相关类似问题还有“用例在运行过程中经常会出现不稳定的情况,也就是说这次 可以通过,下次就没办法通过了,如何去提升用例的稳定性?”

       “如何提高 selenium 脚本的执行速度?”

       “selenium 中如何保证操作元素的成功率?也就是说不管网络加载慢还是快”

       如果一个元素今天你能定位到,过两天就定位不到了,只要这个页面没变过,说 明定位方法是没啥问题的。

       优化方向:

  1. 不要右键复制 xpath(十万八千里那种路径,肯定不稳定),自己写 相对路径,多用 id 为节点查找 

  2. 定位没问题,第二个影响因素那就是等待了,sleep 等待尽量少用(影响执行 时间) driver.implicitly_wait(30)这个等待也不要用,不要以为是全局的就是好事, 有些 js 加载失败时候会一直等,并且页面跳转时候也无法识别

  3. 定位元素方法重新封装,结合 WebDriverWait 和 expected_conditions 判断元 素方法,自己封装一套定位元素方法

from selenium import webdriver
from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.support.ui import WebDriverWait
def find(locator, timeout=30):
'''定位元素,参数 locator 是元祖类型, 如("id", "cemaxueyuan")''' element = WebDriverWait(driver, timeout,
1).until(EC.presence_of_element_located(locator)) return element

3.如何定位动态元素

       动态元素有 2 种情况,一个是属性动态,比如 id 是动态的,定位时候,那就不 要用 id 定位就是了

登录;

       比如上面这个 button 元素,id 是动态的,定位方法千千万,何必死在 id 上, 可以用 name 定位, 哪怕这个元素属性都是动态的,它的标签不可能动态吧,那就定位父元素 id="yo"啊: .//*[@id=‘yo’]/button

       还有一种情况动态的,那就是这个元素一会在页面上方,一会在下方,飘忽不定 的动态元素,定位方法也是一样,按 f12,根据元素属性定位(元素的 tag、name 的步伐属性是不会变的,动的只是 class 属性和 styles 属性)

4.如何通过子元素定位父元素

       面试官尽喜欢搞一些冷门的定位来考求职者,当初我也被这个问题送了小命。回 来后专门查了相关资料,找到了这个定位方法selenium 里面通过父元素,定位子元素,可以通过二次定位来找到该元素,但是通过子元素找父元素这种思维之前真没注意过,实际上 selenium 里面提供 了该方法。

ele1= driver.find_element_by_id(“yoyo”).find_element_by_id(“ziyuans”)

       登录

       虽然用 parent 方法定位到了父元素,但是无法获取元素属性,也不能操作,没 搞懂有啥意义另外一个思路,子元素定位父元素,可以通过 xpath 的语法直接定 位:.//*[@name=“heo”]/… 两个点…就是代表父级元素了。

coding:utf-8
from selenium import webdriver from PIL import Image
driver = webdriver.Chrome() driver.get('http://www.baidu.com/')
driver.save_screenshot('button.png') element = driver.find_element_by_id("su")
print(element.location)# 打印元素坐标
print(element.size)# 打印元素大小
left = element.location['x'] top = element.location['y']
right = element.location['x'] + element.size['width'] bottom = element.location['y'] + element.size['height']
im = Image.open('button.png')
im = im.crop((left, top, right, bottom)) im.save('button.png')

6.平常遇到过哪些问题?如何解决的

       可以把平常遇到的元素定位的一些坑说下,然后说下为什么没定位到,比如动态 id、有 iframe、没加等待等因素。

       如何解决的–百度:测码学院,上面都有解决办法。

7.一个元素明明定位到了,点击无效(也没报错),如果解决?

       使用 js 点击,selenium 有时候点击元素是会失效

js 点击

       js = ‘document.getElementById(“baidu”).click()’ driver.execute_script(js)

       元素的属性隐藏和显示,主要是 type="hidden"和 style="display: none;"属 性来控制的,接下来在元素属性里面让它隐藏

       里有个按钮,是隐藏的

       输入账号

       登录

       访问百度

       这样元素就不会显示了,也就是面试官所说的隐藏属性了

       定位隐藏元素

       前面说了,定位隐藏元素和普通的元素没啥区别,接下来就来验证下,是不是能 定位到呢?

from selenium import webdriver driver = webdriver.Firefox()
driver.get(“http://localhost:63342/test1122/a/b.html”)

定位 type="hidden"隐藏元素

ele1 = driver.find_element_by_id(“yoyo”) print(“打印元素信息:%s” % ele1)

       获取元素属性 

print(ele1.get_attribute(“name”))

       判断元素是否隐藏 

print(ele1.is_displayed())

       运行结果:

       打印元素信息:

<selenium.webdriver.remote.webelement.WebElement (session=“1debdd46-21b1-451e-b8a7-5aeff1d74f9d”, element="{28628a87-7f22-4574-9e14-931f9c6f20e1}")>
hello False

       运行结果可以看出,隐藏元素用普通定位方法,事实上是定位到了呢!

操作隐藏元素

       隐藏元素可以正常定位到,只是不能操作(定位元素和操作元素是两码事,很多 初学者傻傻分不清楚),操作元素是 click,clear,send_keys 这些方法

隐藏输入框元素输入文本

ele1 = driver.find_element_by_id(“yoyo”) ele1.send_keys(“yoyo”)

       隐藏元素用 send_keys()方法会抛异常’ElementNotVisibleException’: Message: Element is not currently visible and so may not be interacted with 这个报错是说元素不可见,不可以被操作,同样的对“登录”按钮点击操作也是 会报’ElementNotVisibleException’

点击隐藏登录框

ele2 = driver.find_element_by_id(“yy”) ele2.click()

JS 操作隐藏元素

       如果面试官想问的是定位后操作隐藏元素的话,本质上说这个问题就是毫无意义 的,web 自动化的目的是模拟人的正常行为去操作。 如果一个元素页面上都看不到了,你人工也是无法操作的是不是?人工都不能操 作,那你自动化的意义又在哪呢?所以这个只是为了单纯的考察面试者处理问题 的能力,没啥实用性!(面试造飞机,进去拧螺丝) 既然面试官这么问了,那就想办法回答上给个好印象吧!

       首先 selenium 是无法操作隐藏元素的(但是能正常定位到),本身这个框架就 是设计如此,如果非要去操作隐藏元素,那就用 js 的方法去操作,selenium 提 供了一个入口可以执行 js 脚本。

       js 和 selenium 不同,只有页面上有的元素(在 dom 里面的),都能正常的操作, 接下来用 js 试试吧!

访问百度 这个链 接是隐藏的,但是能用 js 点到

from selenium import webdriver driver = webdriver.Firefox()
driver.get(“http://localhost:63342/test1122/a/b.html”)

js 点击 hidden 元素

js = ‘document.getElementById(“baidu”).click()’ driver.execute_script(js)

       运行完之后,会发现页面正常的点击,跳转到百度页面了

       备注:百度搜到的可能方法是先用 js 去掉 hidden 属性,再用 selenium 操作, 这个有点多此一举,你既然都已经会用 js 了,何必不一次性到位直接 click 呢?


作者:软件测试开发-虚竹

原文链接:https://blog.csdn.net/shuaigezhou10086/article/details/110634547

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 1.何为冒烟测试冒烟测试是自由测试的一种。冒烟测试在测试中发现问题,找到了一个bug,然后开发人员会来修复这个bug。这时想知道这次修复是否真的解决了程序的bug,或者是否会对其它模块造成影响,就需要针对此问题进行专门测试,这个过程就被称为冒烟测试。在很多情况下,做冒烟测试是开发人员在试图解决一个问题的时候,造成了其它功能模块一系列的连锁反应,原因可能是只集中考虑了一开始的那个问题,而忽略其它的问题,这就可能引起了新的bug。冒烟测试引入到软件测试中,是指测试人员在正规测试一个新版本之前,先投入较少的人力和时间验证一个软件的主要功能,如果主要功能都没有实现,则打回开发组重新开发。这样做的好处是...
            12 12 2558
            分享
          •   一、背景  在我们日常的测试工作中,无论在数据迁移还是系统测试过程中,测试数据准确性和可用性是测试工作的重中之重,测试人员经常需要查询数据库中的数据或手工造测试数据,而登到oracle数据库后有时会发现显示中文乱码的情况,如下图所示:  或者是:  好好的怎么就乱码了呢?明明“之前”访问其他数据库是没问题。在学习和查询相关资料后我解决了这个问题,但由此引发了我对出现汉字乱码问题的学习兴趣,都是什么原因导致的汉字显示乱码呢?  首先,字符集设置不当是影响Oracle数据库汉字显示的关键问题。下文则详细介绍了oracle关于字符集的分类、构成及设定方法,分析了ORACLE数据库汉字显示乱码的常...
            0 0 2021
            分享
          •   在指控广告商和品牌参与"非法抵制"联合利华的诉讼中,X 放弃了对联合利华的索赔,联合利华旗下拥有多芬(Dove)和海尔曼(Hellmann's)等家喻户晓的品牌。去年秋天,X 还起诉了非营利组织"美国媒体事务"(Media Matters for America),试图让该组织保持沉默,因为该组织报道,苹果和 IBM 等大品牌的广告与纳粹内容同时出现。 IBM 在报道后暂停了在 X 上的广告。  这只是马斯克针对批评者和前商业伙伴提起的诉讼之一,因为他还第二次起诉了 OpenAI 以及创始人 Sam Altman 和 Greg Brockma...
            0 0 197
            分享
          •   Selenium-Switch_to  switch_to适用场景:  ● 处理JS弹框  ● 切换frame  ● 切换浏览器窗口    Switch_to处理JS弹框  JavaScript简称JS,应用于HTML网页,通过操纵网页窗口及网页元素,从而实现动态效果。  ▲ JS弹框类型:警告框alert、确认框confirm、提示框prompt    浏览器窗口中如果有JavaScript的弹出框,需要通过switch_to语句处理。  相关方法:  alert = driver.switch_to.alert # 切换焦点到弹框   alert...
            0 0 1118
            分享
          •   软件开发过程中贯穿着缺陷的引入、发现、修复和关闭的过程,包含较多缺陷的软件通常都被认为是低质量的,但是软件测试并不能找出软件中存在的所有缺陷。因此对于缺陷的研究及分析能够更好地预防缺陷的引入,对软件的正常运行和软件质量改进具有重要的意义。  缺陷和模块属性的关联性分析是软件过程度量的一种方法,在实际软件开发过程中,我们发现缺陷与其所在的模块有着密切的联系,因此本文根据缺陷数量以及其所在模块属性进行缺陷分析,多维度深入地分析缺陷,从而提供更全面的缺陷分析。  一、软件缺陷属性  缺陷属性可为两类,一类为软件缺陷的常规属性,如缺陷类型、缺陷发现阶段、缺陷严重程度、缺陷来源等。一类为与缺陷相关的...
            0 0 1655
            分享
      • 51testing软件测试圈微信