[英]python selenium find child elements in loop
我需要解析页面上所有父元素中的一些子元素。
创建页面上所有文章的列表
article_elements = driver.find_elements_by_tag_name('article')
并绑定以获得for循环中的子元素并将所有结果附加到列表之后
for article in article_elements:
title = article.find_element_by_xpath('//article/h2').text
share_count = article.find_element_by_xpath('//footer/div/a/span').text
poinst = article.find_element_by_xpath('//footer/div[2]/div[1]/div[3]').text
meta_info_list.append({'title':title, 'share count':share_count, 'points':poinst})
循环结束后,我得到了40次相同的文章meta(第一篇文章)
{'share count': u'66', 'points': u'53 points', 'title': u'25+ Random Acts Of Genius Vandalism'}
{'share count': u'66', 'points': u'53 points', 'title': u'25+ Random Acts Of Genius Vandalism'}
{'share count': u'66', 'points': u'53 points', 'title': u'25+ Random Acts Of Genius Vandalism'}
{'share count': u'66', 'points': u'53 points', 'title': u'25+ Random Acts Of Genius Vandalism'}
... 40 times
我的整个代码
# coding: utf8
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
import time
driver = webdriver.Chrome()
driver.set_window_size(1024,768)
driver.get('http://www.boredpanda.com/')
time.sleep(2)
meta_info_list = []
article_elements = driver.find_elements_by_tag_name('article')
for article in article_elements:
title = article.find_element_by_xpath('//article/h2').text
share_count = article.find_element_by_xpath('//footer/div/a/span').text
poinst = article.find_element_by_xpath('//footer/div[2]/div[1]/div[3]').text
meta_info_list.append({'title':title, 'share count':share_count, 'points':poinst})
for list in meta_info_list:
print(list)
循环中的XPath表达式必须以一个点开头 ,以特定于上下文:
for article in article_elements:
title = article.find_element_by_xpath('.//article/h2').text
share_count = article.find_element_by_xpath('.//footer/div/a/span').text
poinst = article.find_element_by_xpath('.//footer/div[2]/div[1]/div[3]').text
meta_info_list.append({'title':title, 'share count':share_count, 'points':poinst})
附带说明,您可以使用列表推导来缩短代码:
meta_info_list = [{
'title': article.find_element_by_xpath('.//article/h2').text,
'share count': article.find_element_by_xpath('.//footer/div/a/span').text,
'points': article.find_element_by_xpath('.//footer/div[2]/div[1]/div[3]').text
} for article in article_elements]
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.