Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk Mengabaikan Ruang Nama XML untuk Lokasi Elemen dalam Python ElementTree?

Bagaimana untuk Mengabaikan Ruang Nama XML untuk Lokasi Elemen dalam Python ElementTree?

Linda Hamilton
Linda Hamiltonasal
2024-10-26 07:18:30512semak imbas

How to Ignore XML Namespaces for Element Location in 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 elemen tanpa awalan ruang nama.

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn