栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

无法遍历Selenium python中的元素

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

无法遍历Selenium python中的元素

1.

i.find_element(By.XPATH,'//p[@]')
在第二个循环中进行迭代时,不断重复获取第一个元素的原因是,开始处
//
尝试从根/顶层定位元素,
而不是 作为的后代元素
i
。这样,
p.partial_entry
每次外循环的每次迭代都将继续返回第一个元素。

要搜索

i
匹配的后代元素
p[@]
,xpath应该以开头
.//
。这就是点的作用。

2. 对于该行

print i.find_element(By.CSS_SELECTOR, 'p.partial_entry')

单身汉
find_element
返回第一个找到的元素,如果找不到则抛出错误。有些’div.wrap’没有那个后代元素,所以您会得到
NoSuchElementException

find_elements
(注意“S”)方法返回元素的列表或一个空列表,如果没有找到,而不是一个错误。

因此,将所有这些放在一起:

>>> for i in driver.find_elements_by_xpath("//div[@]"):...     for ent in i.find_elements_by_xpath('.//p[@]'):...         print ent.text...         if i.find_elements_by_css_selector('#REVIEWS .googleTranslation>.link'):...  print 'translation available'...     print  # output clarity...

顺便说一句,你为什么要混合

find_elements_by_xpath('...')
在一起
find_element(By.XPATH,'...')
呢?坚持一种模式。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/382050.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号