Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Mengabaikan Ruang Nama XML untuk Lokasi Elemen dalam Python ElementTree?
Mengabaikan Ruang Nama XML untuk Lokasi Elemen dalam Python ElementTree
Dalam modul ElementTree, mencari elemen tertentu dalam fail XML boleh menjadi mencabar apabila menghadapi ruang nama, seperti yang digambarkan dalam contoh yang disediakan. Apabila menggunakan kaedah findall, kemasukan {http://www.test.com} sebelum setiap teg menjadi menyusahkan.
Penyelesaian:
Daripada mengubah suai Dokumen XML itu sendiri, pendekatan yang lebih optimum melibatkan pengubahsuaian nama tag selepas menghuraikan XML. Ini membenarkan pengendalian berbilang ruang nama dan alias ruang nama.
Berikut ialah kod yang diubah suai menggunakan fungsi iterparse:
<code class="python">from io import StringIO # for Python 2 import from StringIO instead import xml.etree.ElementTree as ET with open('test.xml', 'r') as f: xml = f.read() it = ET.iterparse(StringIO(xml)) for _, el in it: _, _, el.tag = el.tag.rpartition('}') # strip ns root = it.root</code>
Dengan menetapkan _, _, el.tag = el.tag. rpartition('}'), ruang nama (_{http://www.test.com}) dilucutkan daripada nama tag. Ini membolehkan pemprosesan teg seterusnya tanpa mengambil kira ruang nama mereka. Akibatnya, kaedah findall:
<code class="python">el1 = root.findall("DEAL_LEVEL/PAID_OFF")</code>
akan mengembalikan
Atas ialah kandungan terperinci Bagaimana untuk Mengabaikan Ruang Nama XML untuk Lokasi Elemen dalam Python ElementTree?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!