扫地的大伯
2020-12-25 16:03
采纳率: 100%
浏览 172

Python爬虫 Selenium定位元素问题

大佬们好,

我想要通过selenium点击“下载公告文件”这个按钮,实现自动下载文件的功能。然而尝试了许多方式都无法准确定位,不知道这类没有id, class之类的元素要如何准确定位。如图。

尝试过的代码如下。

from selenium import webdriver
import time
driver = webdriver.Chrome()

driver.get('https://ecp.sgcc.com.cn/ecp2.0/portal/#/doc/doci-bid/2020122381634715_2018032700291334')
time.sleep(5)

button = driver.find_element_by_class_name('td_1').find_element_by_tag_name('span')
#driver.find_element_by_xpath('//span[@_ngcontent-c8=""]').click()
#driver.find_element_by_tag_name('a').find_elements_by_tag_name('span')
#driver.find_element_by_xpath("/html/body/app-root/app-main/app-doc/app-doci-bid/div/div/div/div[1]/table/tbody/tr[9]/td[1]/a/span").click()
#driver.find_element_by_tag_name('span').click()

print(button)
button.click()

终端报错信息为 selenium.common.exceptions.NoSuchElementException: Message: no such element: Unable to locate element: {"method":"class name","selector":"td_1"} 浏览器是可以正常打开的。

麻烦各位大佬帮帮忙,谢谢!

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • ma390738719 2020-12-25 16:15
    已采纳

    你好,可以通过xpath定位。打开F12,定位到元素上右键Copy-Copy Xpath即可获得该元素的xpath

    打赏 评论
  • 你好,你可以先排查是否定位到当前的页面、是否存在iframe,如果存在,是否切换到内

    2、针对当个元素而言,可以使用xpath相对路径,//span[text()="下载公告文件"]

    2 打赏 评论
  • 码渝 2020-12-25 16:16

    你好,可以采用元素层级定位的方法

    打赏 评论

相关推荐 更多相似问题