python xml添加命名空间_XML的命名空间与python解析方法
在 XML 中,元素名稱是由開(kāi)發(fā)者定義的,當(dāng)兩個(gè)不同的文檔使用相同的元素名時(shí),就會(huì)發(fā)生命名沖突,而XML 命名空間提供避免元素命名沖突的方法。
XML 命名空間屬性被放置于元素的開(kāi)始標(biāo)簽之中,并使用以下的語(yǔ)法:
xmlns:namespace-prefix="namespaceURI"
當(dāng)命名空間被定義在元素的開(kāi)始標(biāo)簽中時(shí),所有帶有相同前綴的子元素都會(huì)與同一個(gè)命名空間相關(guān)聯(lián)。
注釋:用于標(biāo)示命名空間的地址不會(huì)被解析器用于查找信息。其惟一的作用是賦予命名空間一個(gè)惟一的名稱。
除了顯式定義,為元素定義默認(rèn)的命名空間可以讓我們省去在所有的子元素中使用前綴的工作。也就是說(shuō)所有沒(méi)有前綴的標(biāo)簽都會(huì)帶有默認(rèn)的命名空間
請(qǐng)使用下面的語(yǔ)法:
xmlns="namespaceURI"
解析帶有命名空間的XML文件時(shí),要注意標(biāo)簽的名字是命名空間與標(biāo)簽的結(jié)合,比如下面的XML文件:
5.0
其中默認(rèn)的命名空間為xmls,另外聲明了兩個(gè)命名空間xmlns:vuln和xmlns:cvss。如果使用python的ElementTree解析,下面的代碼是錯(cuò)誤的
node.find('score').text運(yùn)行的時(shí)候會(huì)報(bào)錯(cuò),如下:AttributeError: 'NoneType' object has no attribute 'text'也就是說(shuō),node.find(‘score‘)沒(méi)有找到任何結(jié)果。
正確的訪問(wèn)方式應(yīng)該是這樣的,也就是加上命名空間:
cvss = “{http://abulabula}”
node.find(cvss + 'score')對(duì)于例子中的entry這種沒(méi)有顯式前綴的標(biāo)簽,他們是帶有隱式前綴xmlns的,所以訪問(wèn)時(shí)要加上x(chóng)mlns的值
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的python xml添加命名空间_XML的命名空间与python解析方法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 函数模板(参考《C++ Template
- 下一篇: 算法基础:递归算法知识笔记