Beautiful Soup-문서의 일부만 구문 분석
Beautifulsoup4를 사용하여 특정 유형의 정보 (<a> 태그 만)를 추출하려는 여러 상황이 있습니다. Beautifulsoup의 SoupStrainer 클래스를 사용하면 들어오는 문서의 특정 부분 만 구문 분석 할 수 있습니다.
한 가지 방법은 SoupStrainer를 만들고 Parse_only 인수로 Beautifulsoup4 생성자에 전달하는 것입니다.
수프 스트레이너
SoupStrainer는 BeautifulSoup에게 어떤 부분이 추출되는지 알려주고 구문 분석 트리는 이러한 요소로만 구성됩니다. 필요한 정보를 HTML의 특정 부분으로 좁 히면 검색 결과가 빨라집니다.
product = SoupStrainer('div',{'id': 'products_list'})
soup = BeautifulSoup(html,parse_only=product)
위의 코드 줄은 태그 필드 안에있을 수있는 제품 사이트의 제목 만 구문 분석합니다.
마찬가지로 위와 같이 다른 soupStrainer 개체를 사용하여 HTML 태그에서 특정 정보를 구문 분석 할 수 있습니다. 다음은 몇 가지 예입니다.
from bs4 import BeautifulSoup, SoupStrainer
#Only "a" tags
only_a_tags = SoupStrainer("a")
#Will parse only the below mentioned "ids".
parse_only = SoupStrainer(id=["first", "third", "my_unique_id"])
soup = BeautifulSoup(my_document, "html.parser", parse_only=parse_only)
#parse only where string length is less than 10
def is_short_string(string):
return len(string) < 10
only_short_strings =SoupStrainer(string=is_short_string)