pythonselenium地址栏_如何访问所有URL的Selenium Python

您的问题是由于您的不良实践使用:try:

do something

except:

pass

使用这一行代码块,您无法获取有关程序为何按预期运行的任何信息。它抛出的异常可以帮助您改进代码,不要这样做。

现在,回到你的问题上来。在您的代码中,有一些逻辑错误,如@Mohammad Rakib Amin's answer。所以,稍微修改一下你的代码,你就知道了:

^{pr2}$

但这并没有解决您的问题,您的浏览器将只访问这个第一个url

就像你所描述的,并提出一个例外:StaleElementReferenceException: Message: stale element reference: element is not attached to the page document

引发此异常是因为在第二个循环期间,您正在使用的元素不再附加到浏览器的当前页面。在

解决这个问题的方法就像您所做的一样,找到所有元素并将所有url附加到一个列表中。你像这样重复这个列表,它在我的电脑上运行得很好。试试看:from selenium import webdriver

browser = webdriver.Chrome()

query_url = "https://www.google.co.uk/search?q=Rashmi&oq=Rashmi&aqs=chrome..69i57j69i60l3.6857j0j1&sourceid=chrome&ie=UTF-8#q=Rashmi+Custom+Tailors"

browser.get(query_url)

p_links = browser.find_elements_by_css_selector("div > h3 > a")

urls = []

for elem in p_links:

text = elem.text

url = elem.get_property('href')

if "Rashmi Custom Tailors" in elem.text:

urls.append(url)

for url in urls:

browser.get(url)

也许您在第二个循环中做了一些indent error。在

附言:你的问题应该包含所有需要的代码,这样别人就更容易帮助你了。在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值