Python을 사용하여 HTML 파일에서 텍스트 추출: 종합 안내서
소개
텍스트 추출 HTML 파일의 데이터는 다양한 데이터 처리 및 분석 작업에 필수적일 수 있습니다. 간단한 HTML 구조에서는 정규 표현식을 사용할 수 있지만 형식이 잘못된 코드에서는 어려움을 겪을 수 있습니다. 이 기사에서는 강력한 대안인 Beautiful Soup을 탐색하고 원치 않는 JavaScript를 효과적으로 제거하고 HTML 엔터티를 해석하는 실용적인 솔루션을 제공합니다.
Beautiful Soup 사용
다음을 사용하여 텍스트를 추출하려면 Beautiful Soup은 다음 단계를 따르세요.
- BeautifulSoup 가져오기 library.
- urlopen()을 사용하여 HTML 파일을 엽니다.
- BeautifulSoup(html, feature="html.parser")를 사용하여 BeautifulSoup 객체를 생성합니다.
- 원하지 않는 요소 제거( 예를 들어 스크립트 및 스타일) for script in 수프(["script", "style"]): script.extract().
- soup.get_text()를 사용하여 텍스트를 추출합니다.
- 텍스트를 줄로 나누고 줄을 사용하여 공백을 제거합니다. = (line.strip() 텍스트의 줄 .splitlines()).
- 청크로 여러 헤드라인 분리 = (phrase.strip() for line in line for문구 in line.split(" ")).
- text = 'n'.join(chunk for Chunk in Chunks if Chunk).
코드 예
전체 코드는 다음과 같습니다. 예:
from urllib.request import urlopen from bs4 import BeautifulSoup url = "http://news.bbc.co.uk/2/hi/health/2284783.stm" html = urlopen(url).read() soup = BeautifulSoup(html, features="html.parser") for script in soup(["script", "style"]): script.extract() text = soup.get_text() lines = (line.strip() for line in text.splitlines()) chunks = (phrase.strip() for line in lines for phrase in line.split(" ")) text = '\n'.join(chunk for chunk in chunks if chunk) print(text)
추가 옵션
- html2text: HTML 엔터티를 처리하고 JavaScript를 무시하는 대체 라이브러리입니다. 그러나 일반 텍스트 대신 Markdown을 생성합니다.
- lxml: 태그를 제거한 후 텍스트도 추출할 수 있는 강력한 XML 및 HTML 파서 라이브러리입니다.
결론
이 가이드는 다음을 사용하여 HTML 파일에서 텍스트를 추출하는 포괄적인 솔루션을 제공합니다. BeautifulSoup. 원치 않는 요소를 제거하고 HTML 엔터티를 해석함으로써 추가 처리 및 분석을 위한 일반 텍스트 출력을 효과적으로 생성합니다.
위 내용은 Python을 사용하여 HTML 파일에서 깨끗한 텍스트를 효율적으로 추출하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Python은 웹 개발, 데이터 과학, 기계 학습, 자동화 및 스크립팅 분야에서 널리 사용됩니다. 1) 웹 개발에서 Django 및 Flask 프레임 워크는 개발 프로세스를 단순화합니다. 2) 데이터 과학 및 기계 학습 분야에서 Numpy, Pandas, Scikit-Learn 및 Tensorflow 라이브러리는 강력한 지원을 제공합니다. 3) 자동화 및 스크립팅 측면에서 Python은 자동화 된 테스트 및 시스템 관리와 같은 작업에 적합합니다.

2 시간 이내에 파이썬의 기본 사항을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우십시오. 이를 통해 간단한 파이썬 프로그램 작성을 시작하는 데 도움이됩니다.

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?

Fiddlerevery Where를 사용할 때 Man-in-the-Middle Reading에 Fiddlereverywhere를 사용할 때 감지되는 방법 ...

Python 3.6에 피클 파일로드 3.6 환경 보고서 오류 : modulenotfounderror : nomodulename ...

경치 좋은 스팟 댓글 분석에서 Jieba Word 세분화 문제를 해결하는 방법은 무엇입니까? 경치가 좋은 스팟 댓글 및 분석을 수행 할 때 종종 Jieba Word 세분화 도구를 사용하여 텍스트를 처리합니다 ...

정규 표현식을 사용하여 첫 번째 닫힌 태그와 정지와 일치하는 방법은 무엇입니까? HTML 또는 기타 마크 업 언어를 다룰 때는 정규 표현식이 종종 필요합니다.

Investing.com의 크롤링 전략 이해 많은 사람들이 종종 Investing.com (https://cn.investing.com/news/latest-news)에서 뉴스 데이터를 크롤링하려고합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

드림위버 CS6
시각적 웹 개발 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

뜨거운 주제



