我试图在以下网址上搜索一场足球比赛的比赛统计数据:
https://www.flashscore.com/match/8S0QVm38/#match-statistics;0
我编写了代码,只为Webdriver选择我想要的统计数据并为我打印,以便我可以看到我想要使用的内容。我的代码是:
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
browser = webdriver.Firefox()
browser.get("https://www.flashscore.com/match/8S0QVm38/#match-statistics;0")
print(browser.find_elements_by_class_name("statText--homeValue"))
打印出一个元素列表,说实话,我不知道这是不是我正在寻找的东西,因为返回的内容并没有显示任何与我在开发人员工具中看到的内容有关。
我试图在Possession和目标上的镜头等统计数据下获取所有数字,但是print会返回一个像这样的xpath列表,其中会话是相同的,但元素总是不同的:
[<selenium.webdriver.firefox.webelement.FirefoxWebElement (session="da88ca87-e318-934e-ba75-dca1d652cd37", element="c53f5f3e-2c89-b34c-a639-ab50fbbf0c33")>,
<selenium.webdriver.firefox.webelement.FirefoxWebElement (session="da88ca87-e318-934e-ba75-dca1d652cd37", element="3e422b45-e26d-de44-8994-5f9788462ec4")>,
<selenium.webdriver.firefox.webelement.FirefoxWebElement (session="da88ca87-e318-934e-ba75-dca1d652cd37", element="9e110a54-4ecb-fb4b-9d8f-ccd1b210409d")>, <
任何人都知道这是为什么以及我能做些什么来获得实际数字?
你得到的不是XPath,而是WebElement对象的列表。从每次尝试中获取文本
print([node.text for node in browser.find_elements_by_class_name("statText--homeValue")])
您已打印生成器而不是实际内容。为此,你必须为每个元素使用.text
。喜欢,
elements = browser.find_elements_by_class_name("statText--homeValue")
for element in elements:
print(element.text)
您也可以选择Andersson's answer中显示的列表综合方法。
希望这可以帮助!干杯!