아름다운 수프-나무 수정
BeautifulSoup의 중요한 측면 중 하나는 구문 분석 트리를 검색하는 것이며 요구 사항에 따라 웹 문서를 변경할 수 있습니다. .name, .string 또는 .append () 메소드와 같은 속성을 사용하여 태그의 속성을 변경할 수 있습니다. .new_string () 및 .new_tag () 메서드를 사용하여 기존 태그에 새 태그와 문자열을 추가 할 수 있습니다. HTML 또는 XML 문서를 다양하게 수정하기위한 .insert (), .insert_before () 또는 .insert_after ()와 같은 다른 메소드도 있습니다.
태그 이름 및 속성 변경
스프를 만든 후에는 태그 이름 변경, 속성 수정, 새 속성 추가 및 속성 삭제와 같은 수정을 쉽게 수행 할 수 있습니다.
>>> soup = BeautifulSoup('<b class="bolder">Very Bold</b>')
>>> tag = soup.b
수정 및 새 속성 추가는 다음과 같습니다.
>>> tag.name = 'Blockquote'
>>> tag['class'] = 'Bolder'
>>> tag['id'] = 1.1
>>> tag
<Blockquote class="Bolder" id="1.1">Very Bold</Blockquote>
삭제 속성은 다음과 같습니다-
>>> del tag['class']
>>> tag
<Blockquote id="1.1">Very Bold</Blockquote>
>>> del tag['id']
>>> tag
<Blockquote>Very Bold</Blockquote>
.string 수정
태그의 .string 속성을 쉽게 수정할 수 있습니다.
>>> markup = '<a href="https://www.tutorialspoint.com/index.htm">Must for every <i>Learner>/i<</a>'
>>> Bsoup = BeautifulSoup(markup)
>>> tag = Bsoup.a
>>> tag.string = "My Favourite spot."
>>> tag
<a href="https://www.tutorialspoint.com/index.htm">My Favourite spot.</a>
위에서부터 태그에 다른 태그가 포함되어 있는지 확인할 수 있으며 해당 태그와 모든 내용이 새 데이터로 대체됩니다.
append ()
기존 태그에 새로운 데이터 / 내용을 추가하는 것은 tag.append () 메소드를 사용하는 것입니다. Python 목록의 append () 메서드와 매우 유사합니다.
>>> markup = '<a href="https://www.tutorialspoint.com/index.htm">Must for every <i>Learner</i></a>'
>>> Bsoup = BeautifulSoup(markup)
>>> Bsoup.a.append(" Really Liked it")
>>> Bsoup
<html><body><a href="https://www.tutorialspoint.com/index.htm">Must for every <i>Learner</i> Really Liked it</a></body></html>
>>> Bsoup.a.contents
['Must for every ', <i>Learner</i>, ' Really Liked it']
NavigableString () 및 .new_tag ()
문서에 문자열을 추가하려는 경우 append () 또는 NavigableString () 생성자를 사용하여 쉽게 수행 할 수 있습니다.
>>> soup = BeautifulSoup("<b></b>")
>>> tag = soup.b
>>> tag.append("Start")
>>>
>>> new_string = NavigableString(" Your")
>>> tag.append(new_string)
>>> tag
<b>Start Your</b>
>>> tag.contents
['Start', ' Your']
Note: NavigableString () 함수에 액세스하는 동안 다음과 같이 이름 오류를 발견하면-
NameError : 'NavigableString'이름이 정의되지 않았습니다.
bs4 패키지에서 NavigableString 디렉토리를 가져옵니다.
>>> from bs4 import NavigableString
위의 오류를 해결할 수 있습니다.
기존 태그에 주석을 추가하거나 NavigableString의 다른 하위 클래스를 추가 할 수 있습니다. 생성자를 호출하기 만하면됩니다.
>>> from bs4 import Comment
>>> adding_comment = Comment("Always Learn something Good!")
>>> tag.append(adding_comment)
>>> tag
<b>Start Your<!--Always Learn something Good!--></b>
>>> tag.contents
['Start', ' Your', 'Always Learn something Good!']
완전히 새로운 태그를 추가 (기존 태그에 추가하지 않음)는 Beautifulsoup 내장 메소드 BeautifulSoup.new_tag ()를 사용하여 수행 할 수 있습니다.
>>> soup = BeautifulSoup("<b></b>")
>>> Otag = soup.b
>>>
>>> Newtag = soup.new_tag("a", href="https://www.tutorialspoint.com")
>>> Otag.append(Newtag)
>>> Otag
<b><a href="https://www.tutorialspoint.com"></a></b>
첫 번째 인수 인 태그 이름 만 필요합니다.
끼워 넣다()
파이썬 목록의 .insert () 메서드와 유사하게 tag.insert ()는 새 요소를 삽입하지만 tag.append ()와는 달리 새 요소가 반드시 부모 콘텐츠의 끝에있는 것은 아닙니다. 새 요소는 모든 위치에 추가 할 수 있습니다.
>>> markup = '<a href="https://www.djangoproject.com/community/">Django Official website <i>Huge Community base</i></a>'
>>> soup = BeautifulSoup(markup)
>>> tag = soup.a
>>>
>>> tag.insert(1, "Love this framework ")
>>> tag
<a href="https://www.djangoproject.com/community/">Django Official website Love this framework <i>Huge Community base</i></a>
>>> tag.contents
['Django Official website ', 'Love this framework ', <i>Huge Community base</i
>]
>>>
insert_before () 및 insert_after ()
구문 분석 트리에서 무언가 바로 앞에 태그 나 문자열을 삽입하려면 insert_before ()를 사용합니다.
>>> soup = BeautifulSoup("Brave")
>>> tag = soup.new_tag("i")
>>> tag.string = "Be"
>>>
>>> soup.b.string.insert_before(tag)
>>> soup.b
<b><i>Be</i>Brave</b>
유사하게 구문 분석 트리의 항목 바로 뒤에 태그 나 문자열을 삽입하려면 insert_after ()를 사용합니다.
>>> soup.b.i.insert_after(soup.new_string(" Always "))
>>> soup.b
<b><i>Be</i> Always Brave</b>
>>> soup.b.contents
[<i>Be</i>, ' Always ', 'Brave']
맑은()
태그의 내용을 제거하려면 tag.clear ()를 사용하십시오.
>>> markup = '<a href="https://www.tutorialspoint.com/index.htm">For <i>technical & Non-technical&lr;/i> Contents</a>'
>>> soup = BeautifulSoup(markup)
>>> tag = soup.a
>>> tag
<a href="https://www.tutorialspoint.com/index.htm">For <i>technical & Non-technical</i> Contents</a>
>>>
>>> tag.clear()
>>> tag
<a href="https://www.tutorialspoint.com/index.htm"></a>
추출물()
트리에서 태그 또는 문자열을 제거하려면 PageElement.extract ()를 사용하십시오.
>>> markup = '<a href="https://www.tutorialspoint.com/index.htm">For <i&gr;technical & Non-technical</i> Contents</a>'
>>> soup = BeautifulSoup(markup)
>>> a_tag = soup.a
>>>
>>> i_tag = soup.i.extract()
>>>
>>> a_tag
<a href="https://www.tutorialspoint.com/index.htm">For Contents</a>
>>>
>>> i_tag
<i>technical & Non-technical</i>
>>>
>>> print(i_tag.parent)
None
분해 ()
tag.decompose ()는 트리에서 태그를 제거하고 모든 내용을 삭제합니다.
>>> markup = '<a href="https://www.tutorialspoint.com/index.htm">For <i>technical & Non-technical</i> Contents</a>'
>>> soup = BeautifulSoup(markup)
>>> a_tag = soup.a
>>> a_tag
<a href="https://www.tutorialspoint.com/index.htm">For <i>technical & Non-technical</i> Contents</a>
>>>
>>> soup.i.decompose()
>>> a_tag
<a href="https://www.tutorialspoint.com/index.htm">For Contents</a>
>>>
Replace_with ()
이름에서 알 수 있듯이 pageElement.replace_with () 함수는 이전 태그 또는 문자열을 트리의 새 태그 또는 문자열로 대체합니다.
>>> markup = '<a href="https://www.tutorialspoint.com/index.htm">Complete Python <i>Material</i></a>'
>>> soup = BeautifulSoup(markup)
>>> a_tag = soup.a
>>>
>>> new_tag = soup.new_tag("Official_site")
>>> new_tag.string = "https://www.python.org/"
>>> a_tag.i.replace_with(new_tag)
<i>Material</i>
>>>
>>> a_tag
<a href="https://www.tutorialspoint.com/index.htm">Complete Python <Official_site>https://www.python.org/</Official_site></a>
위의 출력에서 replace_with ()가 교체 된 태그 또는 문자열 (예 : 우리의 경우 "Material")을 반환하므로이를 검사하거나 트리의 다른 부분에 다시 추가 할 수 있습니다.
싸다()
pageElement.wrap ()은 지정한 태그에 요소를 포함하고 새 래퍼를 반환합니다.
>>> soup = BeautifulSoup("<p>tutorialspoint.com</p>")
>>> soup.p.string.wrap(soup.new_tag("b"))
<b>tutorialspoint.com</b>
>>>
>>> soup.p.wrap(soup.new_tag("Div"))
<Div><p><b>tutorialspoint.com</b></p></Div>
풀다()
tag.unwrap ()은 wrap ()과 반대이며 태그를 해당 태그 내부의 모든 것으로 대체합니다.
>>> soup = BeautifulSoup('<a href="https://www.tutorialspoint.com/">I liked <i>tutorialspoint</i></a>')
>>> a_tag = soup.a
>>>
>>> a_tag.i.unwrap()
<i></i>
>>> a_tag
<a href="https://www.tutorialspoint.com/">I liked tutorialspoint</a>
위에서부터 replace_with ()와 마찬가지로 unwrap ()은 대체 된 태그를 반환합니다.
아래는 더 잘 이해하기위한 unwrap ()의 또 다른 예입니다.
>>> soup = BeautifulSoup("<p>I <strong>AM</strong> a <i>text</i>.</p>")
>>> soup.i.unwrap()
<i></i>
>>> soup
<html><body><p>I <strong>AM</strong> a text.</p></body></html>
unwrap ()은 마크 업을 제거하는 데 좋습니다.