当前位置: 首页 > 知识库问答 >
问题:

Python:Xpath无法定位元素

司空修贤
2023-03-14

我试图从一个网站获得一些数据,但得到以下错误。它昨晚起作用了,但当我今天重新运行时,它突然无法定位元素。今天,我尝试了几乎我可以,但无法解决它。

工具和语言-Python、Selenium、Chrome、Chromedriver、AWS Cloud 9、EC2

from selenium import webdriver
import time
from selenium.webdriver.chrome.options import Options
options = Options()
options.headless = True
driver = webdriver.Chrome(options=options)


driver.get('https://www.espncricinfo.com/series/19496/scorecard/1198235/england-vs-australia-1st-t20i-england-v-australia-2020')
time.sleep(20)
element_text = driver.find_element_by_xpath('//*[@id="main-container"]/div/div[2]/div[2]/div/div[1]/div[1]/div[1]/div[1]/div[1]/div[2]').text
print(element_text)

错误消息

selenium.common.exceptions.NoSuchElementException: Message: no such element: Unable to locate element: {"method":"xpath","selector":"//*[@id="main-container"]/div/div[2]/div[2]/div/div[1]/div[1]/div[1]/div[1]/div[1]/div[2]"}

我试过下面的东西

  1. 增加和减少睡眠时间。增加和减少睡眠时间

提到各种网站仍然无法解决。我是python新手。

共有2个答案

邓欣可
2023-03-14

要打印文本1st T20I(N),南安普顿,2020年9月4日,澳大利亚英格兰巡回赛,您可以使用以下任一定位策略:

>

  • 使用class_name和text属性:

    print(driver.find_element_by_class_name("desc").text)
    

    使用css_selectorget_attribute()

    print(driver.find_element_by_css_selector("div.desc").get_attribute("innerHTML"))
    

    使用xpath和文本属性:

    print(driver.find_element_by_xpath("//div[@class='desc text-truncate']").text)
    

    理想情况下,要打印元素的innerText,您必须为元素的visibility\u located()引入WebDriverWait,并且您可以使用以下任一定位器策略:

    >

  • 使用CLASS_NAME

    print(WebDriverWait(driver, 20).until(EC.visibility_of_element_located((By.CLASS_NAME, "desc"))).text)
    

    使用CSS_SELECTOR

    print(WebDriverWait(driver, 20).until(EC.visibility_of_element_located((By.CSS_SELECTOR, "div.desc"))).get_attribute("innerHTML"))
    

    使用XPATH

    print(WebDriverWait(driver, 20).until(EC.visibility_of_element_located((By.XPATH, "//div[@class='desc text-truncate']"))).text)
    

    注意:您必须添加以下导入:

    from selenium.webdriver.support.ui import WebDriverWait
    from selenium.webdriver.common.by import By
    from selenium.webdriver.support import expected_conditions as EC
    

    您可以找到有关如何使用Selenium-Python检索WebElement文本的相关讨论

    链接到有用的文档:

    • get\u attribute()method获取元素的给定属性或属性

  • 宋臻
    2023-03-14

    试试这个:

    import time
    
    from selenium import webdriver
    from selenium.webdriver.chrome.options import Options
    
    options = Options()
    options.headless = True
    driver = webdriver.Chrome(options=options)
    
    url = 'https://www.espncricinfo.com/series/19496' \
          '/scorecard/1198235/england-vs-australia-1st-t20i-england-v-australia-2020'
    driver.get(url)
    time.sleep(2)
    element = driver.find_element_by_xpath('//div[@class="desc text-truncate"]')
    print(element.text)
    

    输出:

    1st T20I (N), Southampton, Sep 4 2020, Australia tour of England
    
     类似资料:
    • 我想在selenium中找到我的文本字段,但我不知道如何找到(我第一次使用sellenium)。 我试过: 或者通过xPath和cssSseltor String在dev工具中由chrome生成。 请帮助我,我将感谢解释。 这是html:

    • 嗨,我是一个相当新的硒。可以有人请建议如何定位和元素在iframe asi是得到错误下面。 带有Iframe标记的DOM按钮元素的屏幕截图 以前编写的代码

    • 问题内容: 我正在尝试搜寻房地产网站上的商品。它有一个aspx表单,必须在提交之前填写。 http://www.cbre.us/PropertyListings/Pages/Properties-for- Sale.aspx 我只关心俄勒冈州的多户家庭财产。所以这是我的第一次尝试: 当我运行此脚本时,出现错误“找不到元素“ ForSalePropertyType”。在这里我在做什么错? 问题答案:

    • 这就是我得到的错误

    • 我正在从包含javascript(评论)的丝芙兰网站上抓取产品评论,但我无法抓取。这是我的代码: 输出为: 回溯(最近的最后一次调用):文件"resgt.py",第15行,在审查中=driver.find_element_by_class_name('css-1jg2pb9 eanm77i0')文件"/home/danish-khan/minicon da3/lib/python3.7/site-

    • 我试图引用并单击网页上的元素。 我们应该能够使用简单的XPath进行引用。例如 然而,这似乎并不奏效。 我使用的chrome扩展表示该元素不存在。 我的代码找不到元素。 下面是我使用Selenium web驱动程序的Java代码。 以下是错误: 太奇怪了!关于为什么我不能引用元素,或者为什么xPath不exist的任何想法。