在bs4.element.Tag中查找链接

时间:2019-03-05 00:18:54

标签: python beautifulsoup

我提取了我想要的链接:

link_soup = soup.find_all('ul', 'pagination')

但是现在我不能使用link_soup[0].find_all('a')['href']

它仅显示第一个链接,该链接不是我想要的。我该如何获取列表中返回的所有链接?

以下代码段:

link_soup[0].find('a')['href']

1 个答案:

答案 0 :(得分:1)

首先,您需要使用parent查找find标签,然后使用child查找所有find_all。希望这会有所帮助

from bs4 import BeautifulSoup
html="""<html><ul class="pagination">
<li><a href="link">&lt;&lt;</a></li>
<li><a href="link">&lt;</a></li>
<li class="hidden-xs"><a href="link">1</a></li>
<li class="hidden-xs active"><a href="link">2</a></li>
<li class="hidden-xs"><a href="link">3</a></li>
<li class="hidden-xs"><a href="link">4</a></li>
<li class="hidden-xs"><a href="link">5</a></li>
<li><a href="link"> &gt;</a></li>
<li><a href="link"> &gt;&gt;</a></li>
</ul></html>"""

soup=BeautifulSoup(html,"html.parser")
ul=soup.find('ul')
for a in ul.find_all('a'):
  print(a['href'])

输出:

link
link
link
link
link
link
link
link
link