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

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵