selenium python怎么读_[置顶] Python selenium —— 动态id、class怎么定位

今天再给大家分享1个定位不到元素的缘由——动态id。

没有打开新页面、没有alert、没有frame、加了等待时间,但是还是定位不到元素?很有多是你要定位的元素的属性是动态的,即每次打开页面,这个元素的id或class等元素属性是动态生成的。代码履行时,元素的属性已与之前不同,用之前的属性值去定位自然是定位不到的,会抛出NoSuchElementException。

那末,怎样判断元素属性是不是是动态?很简单,1般看到元素属性里有拼接1串数字的,就很有多是动态的。想要分辨,刷新1下阅读器再看该元素,属性值中的数字串改变了,即是动态属性了。

以下:

...

怎样定位这类型的元素呢?

1. 根据其他属性定位

如果有其他固定属性,最早斟酌确当然是根据元素的其他属性来定位,定位方式那末多,何必在这1棵树上吊死。。

2. 根据相对关系定位

根据其附近的父节点、子节点、兄弟节点定位,关于这方面,博主之前的1篇文章可作为参考:Python selenium —— 父子、兄弟、相邻节点定位方式详解

3. 根据DOM顺序index定位

这个很简单,找到该元素在主文档或某级父节点中的index,然后根据index可轻松定位,不过这类方式可能不够稳定,如果可以,还是用其他的方法定位更加适合。

4. 根据部份元素属性定位

xpath中提供了3个非常好的方法来为我们定位部份属性值:

driver.find_element_by_xpath("//div[contains(@id, 'btn-attention')]")

driver.find_element_by_xpath("//div[starts-with(@id, 'btn-attention')]")

driver.find_element_by_xpath("//div[ends-with(@id, 'btn-attention')]") # 这个需要结尾是‘btn-attention’

contains(a, b) 如果a中含有字符串b,则返回true,否则返回false

starts-with(a, b) 如果a是以字符串b开头,返回true,否则返回false

ends-with(a, b) 如果a是以字符串b结尾,返回true,否则返回false

这里要多嘴1句,各种阅读器对xpath的支持情况不1样,像IE就差点,所以有时候会出现xpath在1个阅读器能定位到但在另外一个阅读器定位不到的问题,不要惊讶。。

附上1个此类型问题:

Xpath “ends-with” does not work

更多关于python selenium的文章,请关注我的CSDN专栏:Python Selenium自动化测试详解

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值