아름다운 수프-종류의 물건
html 문서 또는 문자열을 beautifulsoup 생성자에 전달하면 beautifulsoup은 기본적으로 복잡한 html 페이지를 다른 파이썬 객체로 변환합니다. 아래에서는 4 가지 주요 객체 유형에 대해 설명합니다.
Tag
NavigableString
BeautifulSoup
Comments
태그 개체
HTML 태그는 다양한 유형의 콘텐츠를 정의하는 데 사용됩니다. BeautifulSoup의 태그 객체는 실제 페이지 나 문서의 HTML 또는 XML 태그에 해당합니다.
>>> from bs4 import BeautifulSoup
>>> soup = BeautifulSoup('<b class="boldest">TutorialsPoint</b>')
>>> tag = soup.html
>>> type(tag)
<class 'bs4.element.Tag'>
태그에는 많은 속성과 메서드가 포함되어 있으며 태그의 두 가지 중요한 기능은 이름과 속성입니다.
이름 (tag.name)
모든 태그에는 이름이 포함되어 있으며 접미사로 '.name'을 통해 액세스 할 수 있습니다. tag.name은 태그 유형을 반환합니다.
>>> tag.name
'html'
그러나 태그 이름을 변경하면 BeautifulSoup에서 생성 한 HTML 마크 업에도 동일하게 반영됩니다.
>>> tag.name = "Strong"
>>> tag
<Strong><body><b class="boldest">TutorialsPoint</b></body></Strong>
>>> tag.name
'Strong'
속성 (tag.attrs)
태그 개체는 여러 속성을 가질 수 있습니다. 태그 <b class =”boldest”>에는 값이“boldest”인 'class'속성이 있습니다. 태그가 아닌 모든 것은 기본적으로 속성이며 값을 포함해야합니다. 키에 액세스 (위의 예에서 "클래스"에 액세스)하거나 ".attrs"를 통해 직접 액세스하여 속성에 액세스 할 수 있습니다.
>>> tutorialsP = BeautifulSoup("<div class='tutorialsP'></div>",'lxml')
>>> tag2 = tutorialsP.div
>>> tag2['class']
['tutorialsP']
태그의 속성 (추가 / 제거 / 수정)에 대한 모든 종류의 수정을 수행 할 수 있습니다.
>>> tag2['class'] = 'Online-Learning'
>>> tag2['style'] = '2007'
>>>
>>> tag2
<div class="Online-Learning" style="2007"></div>
>>> del tag2['style']
>>> tag2
<div class="Online-Learning"></div>
>>> del tag['class']
>>> tag
<b SecondAttribute="2">TutorialsPoint</b>
>>>
>>> del tag['SecondAttribute']
>>> tag
</b>
>>> tag2['class']
'Online-Learning'
>>> tag2['style']
KeyError: 'style'
다중 값 속성
HTML5 속성 중 일부는 여러 값을 가질 수 있습니다. 가장 일반적으로 사용되는 것은 여러 CSS 값을 가질 수있는 클래스 속성입니다. 기타에는 'rel', 'rev', 'headers', 'accesskey'및 'accept-charset'이 있습니다. 아름다운 수프의 다중 값 속성이 목록으로 표시됩니다.
>>> from bs4 import BeautifulSoup
>>>
>>> css_soup = BeautifulSoup('<p class="body"></p>')
>>> css_soup.p['class']
['body']
>>>
>>> css_soup = BeautifulSoup('<p class="body bold"></p>')
>>> css_soup.p['class']
['body', 'bold']
그러나 속성에 둘 이상의 값이 포함되어 있지만 HTML 표준의 모든 버전에 의해 다중 값 속성이 아닌 경우 아름다운 수프는 속성을 그대로 둡니다.
>>> id_soup = BeautifulSoup('<p id="body bold"></p>')
>>> id_soup.p['id']
'body bold'
>>> type(id_soup.p['id'])
<class 'str'>
태그를 문자열로 바꾸면 여러 속성 값을 통합 할 수 있습니다.
>>> rel_soup = BeautifulSoup("<p> tutorialspoint Main <a rel='Index'> Page</a></p>")
>>> rel_soup.a['rel']
['Index']
>>> rel_soup.a['rel'] = ['Index', ' Online Library, Its all Free']
>>> print(rel_soup.p)
<p> tutorialspoint Main <a rel="Index Online Library, Its all Free"> Page</a></p>
'get_attribute_list'를 사용하면 다중 값인지 여부에 관계없이 항상 목록, 문자열 인 값을 얻을 수 있습니다.
id_soup.p.get_attribute_list(‘id’)
그러나 문서를 'xml'로 구문 분석하면 다중 값 속성이 없습니다.
>>> xml_soup = BeautifulSoup('<p class="body bold"></p>', 'xml')
>>> xml_soup.p['class']
'body bold'
NavigableString
navigablestring 객체는 태그의 내용을 나타내는 데 사용됩니다. 내용에 액세스하려면 ".string"을 태그와 함께 사용하십시오.
>>> from bs4 import BeautifulSoup
>>> soup = BeautifulSoup("<h2 id='message'>Hello, Tutorialspoint!</h2>")
>>>
>>> soup.string
'Hello, Tutorialspoint!'
>>> type(soup.string)
>
문자열을 다른 문자열로 바꿀 수 있지만 기존 문자열을 편집 할 수는 없습니다.
>>> soup = BeautifulSoup("<h2 id='message'>Hello, Tutorialspoint!</h2>")
>>> soup.string.replace_with("Online Learning!")
'Hello, Tutorialspoint!'
>>> soup.string
'Online Learning!'
>>> soup
<html><body><h2 id="message">Online Learning!</h2></body></html>
BeautifulSoup
BeautifulSoup은 웹 리소스를 스크랩하려고 할 때 생성되는 개체입니다. 그래서 그것은 우리가 긁어 내려는 완전한 문서입니다. 대부분의 경우 태그 객체로 취급됩니다.
>>> from bs4 import BeautifulSoup
>>> soup = BeautifulSoup("<h2 id='message'>Hello, Tutorialspoint!</h2>")
>>> type(soup)
<class 'bs4.BeautifulSoup'>
>>> soup.name
'[document]'
코멘트
주석 개체는 웹 문서의 주석 부분을 보여줍니다. NavigableString의 특별한 유형입니다.
>>> soup = BeautifulSoup('<p><!-- Everything inside it is COMMENTS --></p>')
>>> comment = soup.p.string
>>> type(comment)
<class 'bs4.element.Comment'>
>>> type(comment)
<class 'bs4.element.Comment'>
>>> print(soup.p.prettify())
<p>
<!-- Everything inside it is COMMENTS -->
</p>
NavigableString 객체
navigablestring 객체는 태그 자체가 아닌 태그 내의 텍스트를 나타내는 데 사용됩니다.