[英]get text between span with BeautifulSoup
我正在嘗試使用Python中的BeautifulSoup抓取各種站點。 說我有以下html
摘錄:
<div class="member_biography">
<h3>Biography</h3>
<span class="sub_heading">District:</span> AnyState - At Large<br/>
<span class="sub_heading">Political Highlights:</span> AnyTown City Council, 19XX-XX<br/>
<span class="sub_heading">Born:</span> June X, 19XX; AnyTown, Calif.<br/>
<span class="sub_heading">Residence:</span> Some Town<br/>
<span class="sub_heading">Religion:</span> Episcopalian<br/>
<span class="sub_heading">Family:</span> Wife, Some Name; two children<br/>
<span class="sub_heading">Education:</span> Some State College, A.A. 19XX; Some Other State College, B.A. 19XX<br/>
<span class="sub_heading">Elected:</span> 19XX<br/>
</div>
我需要結果采用以下格式:
District: AnyState - At Large
Political Highlights: AnyTown City Council, 19XX-XX
Born: June X, 19XX; AnyTown, Calif.
Residence: Some Town
Religion: Episcopalian
Family: Wife, Some Name; two children
Education: Some State College, A.A. 19XX; Some Other State College, B.A. 19XX
Elected: 19XX
但是,到目前為止,我只能實現以下目標:
District:
Political Highlights:
Born:
Residence:
Religion:
Family:
Education:
Elected:
使用以下代碼:
import urllib.request
import sys
from bs4 import BeautifulSoup
def main(url):
fp = urllib.request.urlopen(url)
site_bytearray = fp.read()
fp.close()
#bs_data = BeautifulSoup(site_str,features="html.parser")
bs_data = BeautifulSoup(site_bytearray,'lxml')
tmplist = bs_data.find_all('span',{'class':'sub_heading'})
for item in tmplist:
print(item.text)
sys.exit(0)
if __name__ == "__main__":
main(sys.argv[1])
簡而言之,我該如何從<span class="sub_heading">District:</span> AnyState - At Large<br/>
提取District
和AnyState - At Large
並將結果存儲在列表中以進行進一步處理?
將您的打印命令替換為:
Python 3.6及更高版本:
print(f'{item.text:<25} {item.next_sibling}')
Python 3-3.5:
print('{:<25} {}'.format(item.text, item.next_sibling))
輸出:
District: AnyState - At Large
Political Highlights: AnyTown City Council, 19XX-XX
Born: June X, 19XX; AnyTown, Calif.
Residence: Some Town
Religion: Episcopalian
Family: Wife, Some Name; two children
Education: Some State College, A.A. 19XX; Some Other State College, B.A. 19XX
Elected: 19XX
您是否嘗試過使用getText()
似乎總是對我getText()
。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.