Python selenium - 在元素循环中查找元素

我想寻求帮助。我尝试在网站https://www.kununu.com/de/volkswagen/kommentare/100上抓取所有文章主标题下的总体评分,但是当我这样做时,它会打印:

4,8

4,8

4,8

4,8

4,8

4,8

4,8

4,8

4,8

4,8

4,8

但评分还有更多,不只是4.8。所以我想在元素循环中找到元素。如果可能的话,我想在这种类型的循环中完成它。这是我的代码:


art = driver.find_elements_by_xpath("//article[@class='index__contentBlock__7vKo-']")

    for i in art:

        pr = i.find_element_by_xpath("//span[@class='index__score__16yy9']").text

        print(pr)


qq_花开花谢_0
浏览 266回答 3
3回答

烙印99

这应该打印所有带有index_score的文章。art = driver.find_elements_by_xpath("//article[@class='index__contentBlock__7vKo-']//span[@class='index__score__16yy9']")for i in art:    print(i.text)

拉丁的传说

您已经收集了艺术的所有元素。您所要做的就是:art = driver.find_elements_by_xpath("//article[@class='index__contentBlock__7vKo-']")for i in art:    print(i.text)让我知道这是否有效。

慕慕森

使用Selenium提取评级,例如2,0Python您必须引发WebDriverWait,并且visibility_of_all_elements_located()可以使用以下任一定位器策略:使用CSS_SELECTOR和get_attribute("innerHTML"):driver.get('https://www.kununu.com/de/volkswagen/kommentare/100')print([my_elem.get_attribute("innerHTML") for my_elem in WebDriverWait(driver, 20).until(EC.visibility_of_all_elements_located((By.CSS_SELECTOR, "div[class^='index__ratingBlock'] span[class^='index__score__']")))])使用XPATH和文本属性:driver.get('https://www.kununu.com/de/volkswagen/kommentare/100')print([my_elem.text for my_elem in WebDriverWait(driver, 20).until(EC.visibility_of_all_elements_located((By.XPATH, "//div[starts-with(@class, 'index__ratingBlock')]//span[starts-with(@class, 'index__score__')]")))])控制台输出:['2,0', '4,5', '3,8', '4,8', '2,8', '4,7', '3,2', '4,0', '4,9', '4,2']注意:您必须添加以下导入:from selenium.webdriver.support.ui import WebDriverWaitfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support import expected_conditions as EC
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python