Güzel Çorba - Ağacı Değiştirmek

BeautifulSoup'un önemli yönlerinden biri ayrıştırma ağacında arama yapmaktır ve ihtiyacınıza göre web belgesinde değişiklik yapmanıza izin verir. .Name, .string veya .append () yöntemi gibi özniteliklerini kullanarak etiketin özelliklerinde değişiklikler yapabiliriz. .New_string () ve .new_tag () yöntemleri yardımıyla mevcut bir etikete yeni etiketler ve dizeler eklemenize olanak tanır. HTML veya XML belgenizde çeşitli değişiklikler yapmak için .insert (), .insert_before () veya .insert_after () gibi başka yöntemler de vardır.

Etiket adlarını ve niteliklerini değiştirme

Çorbayı oluşturduktan sonra, etiketi yeniden adlandırmak, özniteliklerinde değişiklik yapmak, yeni öznitelikler eklemek ve öznitelikleri silmek gibi değişiklikler yapmak kolaydır.

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

Değişiklik yapmak ve yeni nitelikler eklemek aşağıdaki gibidir -

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

Özniteliklerin silinmesi aşağıdaki gibidir -

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

.String değiştiriliyor

Etiketin .string özniteliğini kolayca değiştirebilirsiniz -

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

Yukarıdan, etiketin başka herhangi bir etiket içerip içermediğini görebiliriz, bunlar ve tüm içerikleri yeni verilerle değiştirilecektir.

ekle ()

Mevcut bir etikete yeni veri / içerik eklemek tag.append () yöntemini kullanmaktır. Python listesindeki append () metoduna çok benzer.

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

Bir belgeye bir dize eklemek istemeniz durumunda, bu, append () veya NavigableString () yapıcısı kullanılarak kolayca yapılabilir -

>>> 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 () işlevine erişirken herhangi bir ad hatası bulursanız, aşağıdaki gibi−

NameError: 'NavigableString' adı tanımlanmadı

Sadece bs4 paketinden NavigableString dizinini içe aktarın -

>>> from bs4 import NavigableString

Yukarıdaki hatayı çözebiliriz.

Mevcut etiketinize yorumlar ekleyebilir veya NavigableString'in başka bir alt sınıfını ekleyebilirsiniz, sadece yapıcıyı çağırın.

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

Tamamen yeni bir etiket eklemek (mevcut bir etikete eklenmez) Beautifulsoup dahili yöntemi BeautifulSoup.new_tag () kullanılarak yapılabilir -

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

Yalnızca ilk bağımsız değişken olan etiket adı gereklidir.

ekle ()

Python listesindeki .insert () yöntemine benzer şekilde, tag.insert () yeni öğe ekler, ancak tag.append () 'den farklı olarak, yeni öğe mutlaka üst öğesinin içeriğinin sonuna gitmez. Herhangi bir pozisyonda yeni eleman eklenebilir.

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

Ayrıştırma ağacındaki bir şeyin hemen öncesine bir etiket veya dizge eklemek için, insert_before () kullanılır -

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

Ayrıştırma ağacındaki bir şeyden hemen sonra bir etiket veya dizge eklemek için, insert_after () kullanın.

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

açık()

Bir etiketin içeriğini kaldırmak için tag.clear () kullanın -

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

Ayıkla()

Ağaçtan bir etiketi veya dizeleri kaldırmak için PageElement.extract () kullanın.

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

ayrıştır ()

Tag.decompose (), ağaçtan bir etiketi kaldırır ve tüm içeriğini siler.

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

Şununla değiştir()

Adından da anlaşılacağı gibi pageElement.replace_with () işlevi eski etiketi veya dizeyi ağaçtaki yeni etiket veya dizeyle değiştirir -

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

Yukarıdaki çıktıda, replace_with () işlevinin değiştirilen etiketi veya dizeyi (bizim durumumuzdaki "Malzeme" gibi) döndürdüğünü fark ettiniz, böylece onu inceleyebilir veya ağacın başka bir bölümüne geri ekleyebilirsiniz.

paketlemek()

PageElement.wrap (), belirttiğiniz etikette bir öğe içeriyordu ve yeni bir sarmalayıcı döndürüyor -

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

sarılmamış ()

Tag.unwrap (), wrap () 'nin tam tersidir ve bir etiketi bu etiketin içindeki her şeyle değiştirir.

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

Yukarıdan, replace_with () gibi, wrrap () 'in değiştirilen etiketi döndürdüğünü fark ettiniz.

Aşağıda, daha iyi anlamak için bir tane daha wrrap () örneği verilmiştir -

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

wrrap () işaretlemeyi şeritlemek için iyidir.