selenium定位web元素的方法(二)ID & Class_name

1分钟了解一个测开小知识:

selenium定位web元素的方法(二)ID & Class_name:

之前用浏览器的工具获取Xpath,不需要了解HTML的结构,但是通过ID、Classe_name,就需要了解一些html基础知识~
我们还是先使用和Xpath获取方式一样的操作,先找到元素对应的html结构位置,以提交按钮为例:
在这里插入图片描述

定位到了提交字样所在的位置,此时我们可以通过获取Xpath,定位这个元素。
除此之外,我们也可以使用class_name的方式定位:

提交
在html语言中,可以看到<>中存在class 字样,这个字段的含义我们暂时不深究,只了解是描述元素的一种属性。 那这个元素中有2个class:"btn btn-submit"、"t3-la-icon icon-tijiao" 怎么提取呢? 这两个class对应的意义是不一样的, 前者:"btn btn-submit",对应整个按钮控件 后者:"t3-la-icon icon-tijiao",只对应提交按钮上的图形图标

在这里插入图片描述

因为我们之后需要对整个按钮进行操作,所以取前者,“btn btn-submit”
然后使用find_element_by_class_name(‘btn-submit’),捕捉到这个元素,用于后续操作

这里会发现,html中的class,是"btn btn-submit",取的时候只使用了btn-submit
是因为class可以同时存在多个,定位元素我们只使用最后一个即可。

同时捕捉元素也支持多个class同时捕捉:关键字:find_elements_by_class_name(‘btn-submit’),此时返回的是一个列表格式数据,[]

id的获取方式同class_name,只不过获取的关键字是 id = ‘’
在这里插入图片描述

捕捉元素的关键字:
find_element_by_id
find_elements_by_id

使用id、class_name,捕捉元素的优势在于,能够同时捕捉多个相同元素;另外,id、class_name,在元素只进行位置调换或目录变换等小改动的情况下不会改动,相比于Xpath要更加稳定。

不过由于id、class_name经常存在重复的信息,所以在捕捉精确性上要低于Xpath

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值