Python / BeautifulSoup - як видалити всі теги з елемента?


Відповіді:


108

З BeautifulStoneSoupGone In bs4, це ще простіше в Python3

from bs4 import BeautifulSoup

soup = BeautifulSoup(html)
text = soup.get_text()
print(text)

7
Краще використовувати get_text()замість getText().
SparkAndShine

2
Чому так? Цілком може бути так, але було б корисно зрозуміти, чому.
Thomas Kimber

22
getText () має синтаксис bs3 і не відповідає pep8. Ймовірно, він буде застарілим.
Даніель Сміт


12

Використовуйте get_text () , він повертає весь текст у документі або під тегом у вигляді єдиного рядка Unicode.

Наприклад, видаліть усі різні теги сценарію з наступного тексту:

<td><a href="http://www.irit.fr/SC">Signal et Communication</a>
<br/><a href="http://www.irit.fr/IRT">Ingénierie Réseaux et Télécommunications</a>
</td>

Очікуваний результат:

Signal et Communication
Ingénierie Réseaux et Télécommunications

Ось вихідний код:

#!/usr/bin/env python3
from bs4 import BeautifulSoup

text = '''
<td><a href="http://www.irit.fr/SC">Signal et Communication</a>
<br/><a href="http://www.irit.fr/IRT">Ingénierie Réseaux et Télécommunications</a>
</td>
'''
soup = BeautifulSoup(text)

print(soup.get_text())

7

Ви можете використовувати метод розкладання в bs4:

soup = bs4.BeautifulSoup('<body><a href="http://example.com/">I linked to <i>example.com</i></a></body>')

for a in soup.find('a').children:
    if isinstance(a,bs4.element.Tag):
        a.decompose()

print soup

Out: <html><body><a href="http://example.com/">I linked to </a></body></html>

1

схоже, це так робити! так просто

цим рядком ви об'єднуєте всі текстові частини в поточному елементі

''.join(htmlelement.find(text=True))

1

Код, щоб просто отримати вміст як текст замість html:

Параметр 'html_text' - це рядок, який ви передасте в цій функції для отримання тексту

from bs4 import BeautifulSoup

soup = BeautifulSoup(html_text, 'lxml')
text = soup.get_text()
print(text)

Додано, просто перевірте.
Shaurya Sheth

0

Ось вихідний код: ви можете отримати текст, який точно міститься в URL-адресі

URL = ''
page = requests.get(URL)
soup = bs4.BeautifulSoup(page.content,'html.parser').get_text()
print(soup)
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.