首页 > 解决方案 > 如何在 Beautiful Soup 中找到特定的 div 文本

问题描述

我有以下html:

from bs4 import BeautifulSoup as soup
html_doc = """<div class="__cast-member" content="Vishal Krishna Reddy" itemprop="name"><div class="__cast-image wow fadeIn"><meta content="https://in.bmscdn.com/iedb/artist/images/website/poster/large/vishal-krishna-reddy-16275-24-03-2017-15-17-54.jpg" itemprop="image"><img alt="Vishal Krishna Reddy" data-error="//in.bmscdn.com/webin/profile/user.jpg" data-lazy="//in.bmscdn.com/iedb/artist/images/website/poster/large/vishal-krishna-reddy-16275-24-03-2017-15-17-54.jpg" title="Vishal Krishna Reddy"/></meta></div><br/>Developer<br><span class="__role">Actor</span><br><span class="__characterName">As Kathiravan</span></br></br></div>"""
html = soup(html_doc, "html.parser")
Cast=html.find("div", {"class":"__cast-member"})
print Cast.text

输出:DeveloperActorAs Kathiravan

但我只需要输出:开发人员

标签: pythonpython-3.xbeautifulsoup

解决方案


您可以使用该.next_sibling属性来获取所需的文本。找到带有first的<div>标签。class="__cast-image wow fadeIn"您想要的文本位于此标记之后。所以,.next_sibling在这个标签上使用。但首先你会得到<br/>,所以再次使用它。

>>> soup.find('div', class_='__cast-image').next_sibling
<br/>
>>> soup.find('div', class_='__cast-image').next_sibling.next_sibling
'Developer'

推荐阅读