Beautiful Soup - Memodifikasi pohon

Salah satu aspek penting dari BeautifulSoup adalah mencari pohon parse dan memungkinkan Anda untuk membuat perubahan pada dokumen web sesuai dengan kebutuhan Anda. Kita bisa membuat perubahan pada properti tag menggunakan atributnya, seperti metode .name, .string atau .append (). Ini memungkinkan Anda untuk menambahkan tag dan string baru ke tag yang ada dengan bantuan metode .new_string () dan .new_tag (). Ada juga metode lain, seperti .insert (), .insert_before () atau .insert_after () untuk membuat berbagai modifikasi pada dokumen HTML atau XML Anda.

Mengubah nama dan atribut tag

Setelah Anda membuat sup, Anda dapat dengan mudah melakukan modifikasi seperti mengganti nama tag, mengubah atribut, menambahkan atribut baru, dan menghapus atribut.

>>> soup = BeautifulSoup('<b class="bolder">Very Bold</b>')
>>> tag = soup.b

Modifikasi dan penambahan atribut baru adalah sebagai berikut -

>>> tag.name = 'Blockquote'
>>> tag['class'] = 'Bolder'
>>> tag['id'] = 1.1
>>> tag
<Blockquote class="Bolder" id="1.1">Very Bold</Blockquote>

Menghapus atribut adalah sebagai berikut -

>>> del tag['class']
>>> tag
<Blockquote id="1.1">Very Bold</Blockquote>
>>> del tag['id']
>>> tag
<Blockquote>Very Bold</Blockquote>

Memodifikasi .string

Anda dapat dengan mudah mengubah atribut .string dari tag -

>>> 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>

Dari atas, kita dapat melihat apakah tag tersebut mengandung tag lain, mereka dan semua isinya akan diganti dengan data baru.

menambahkan()

Menambahkan data / konten baru ke tag yang ada adalah dengan menggunakan metode tag.append (). Ini sangat mirip dengan metode append () dalam daftar Python.

>>> 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 () dan .new_tag ()

Jika Anda ingin menambahkan string ke dokumen, ini dapat dilakukan dengan mudah dengan menggunakan append () atau dengan konstruktor 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: Jika Anda menemukan nama apa pun Kesalahan saat mengakses fungsi NavigableString (), sebagai berikut-

NameError: name 'NavigableString' tidak ditentukan

Cukup impor direktori NavigableString dari paket bs4 -

>>> from bs4 import NavigableString

Kami dapat mengatasi kesalahan di atas.

Anda dapat menambahkan komentar ke tag yang ada atau dapat menambahkan subkelas NavigableString lainnya, cukup panggil konstruktor.

>>> 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!']

Menambahkan tag baru (tidak menambahkan ke tag yang ada) dapat dilakukan menggunakan metode inbuilt 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>

Hanya argumen pertama, nama tag, yang diperlukan.

memasukkan()

Mirip dengan metode .insert () pada daftar python, tag.insert () akan memasukkan elemen baru namun, tidak seperti tag.append (), elemen baru tidak harus berada di akhir konten induknya. Elemen baru dapat ditambahkan di posisi manapun.

>>> 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 () dan insert_after ()

Untuk menyisipkan beberapa tag atau string sebelum sesuatu di pohon parse, kita menggunakan 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>

Demikian pula untuk menyisipkan beberapa tag atau string tepat setelah sesuatu di pohon parse, gunakan 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']

bersih()

Untuk menghapus konten tag, gunakan 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>

ekstrak()

Untuk menghapus tag atau string dari pohon, gunakan 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

membusuk()

Tag.decompose () menghapus tag dari pohon dan menghapus semua isinya.

>>> 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>
>>>

Ubah dengan()

Seperti namanya, fungsi pageElement.replace_with () akan mengganti tag atau string lama dengan tag atau string baru di pohon -

>>> 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>

Pada keluaran di atas, Anda telah memperhatikan bahwa replace_with () mengembalikan tag atau string yang telah diganti (seperti "Material" dalam kasus kami), sehingga Anda dapat memeriksanya atau menambahkannya kembali ke bagian lain dari pohon.

membungkus()

PageElement.wrap () menyertakan elemen dalam tag yang Anda tentukan dan mengembalikan pembungkus baru -

>>> 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>

membuka()

Tag.unwrap () berlawanan dengan wrap () dan mengganti tag dengan apa pun di dalam tag itu.

>>> 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>

Dari atas, Anda telah memperhatikan bahwa seperti replace_with (), unwrap () mengembalikan tag yang telah diganti.

Di bawah ini adalah satu lagi contoh unwrap () untuk memahaminya dengan lebih baik -

>>> 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 () baik untuk menghilangkan markup.