如何使用 Selenium Python 提取 href?

How to extract href using Selenium Python?

<a class="j-search-result-value jiveTT-hover-user" data-userid="12345" href="/people/ARNLWS"><span class="j-search-result-title">Aaron Lewis</span></a>

<a class="j-search-result-value jiveTT-hover-user" data-userid="99886" href="/people/DONLDTUMP"><span class="j-search-result-title">Donald Trump</span></a>

如何从上面提取href?我尝试使用 find_element_by_class_name 但 returns NoSuchElementException: Message: no such element: Unable to locate element: {"method":"css selector","selector":".j-search-result-value jiveTT-hover-user"}

我的代码:

driver = webdriver.Chrome(r'xxxx\chromedriver.exe')

driver.get("xxx")

eList = driver.find_element_by_class_name('j-search-result-value jiveTT-hover-user')

hrefList = []
for e in eList:
   hrefList.append(e.get_attribute('href'))

for href in hrefList:
   print(href)

我之所以没有使用 xpath,是因为它可能因网址而异。 任何帮助表示赞赏!谢谢。

想法: 建议找到那些包含 data-userid 属性的元素,然后提取它们的 href 属性:

未经测试的伪代码:

eList = driver.find_elements_by_x_path('//a[@data-userid]')

hrefList = []
for e in eList:
   hrefList.append(e.get_attribute('href'))

for href in hrefList:
   print(href)

方法 .find_element_by_class_name 仅适用于单个 class 名称。

要收集元素列表,您必须使用 .find_elements 而不是 .find_element

我建议你这样使用.find_elements_by_css_selector

eList = driver.find_elements_by_css_selector('.j-search-result-value.jiveTT-hover-user')