如何从root中的xmlns获取XML文件中的数据

时间:2018-02-08 00:11:46

标签: python xml tree elementtree

number.xml

<?xml version="1.0" encoding="utf-8"?>
<ResponseSent>
  <ResponseDate xmlns="http://example.com/schema">
   <emailid>123@test.com</emailid>
    <number>22</number>
    <sent>2017-12-05</sent>
 </ResponseDate>

number.py

import xml.etree.ElementTree as ET
tree = ET.parse('number.xml')
root = tree.getroot()
for country in root.findall('ResponseDate'):
    rank = country.find('emailid').text
    name = country.find('number').text
    print(name, rank)

返回空结果,但是当我将xml修改为name =而不是xmlns =时,它正在工作。但是,如何使这个脚本与xmlns一起使用。?

1 个答案:

答案 0 :(得分:4)

请注意,XML中没有前缀的xmlns声明默认命名空间,而没有前缀的后代元素隐式地从祖先继承默认命名空间。现在可以在命名空间中找到元素 定义引用名称空间URI的前缀,并使用该前缀和目标元素的本地名称的组合:

....
ns = { 'd': 'http://example.com/schema' }
for country in root.findall('d:ResponseDate', ns):
    rank = country.find('d:emailid', ns).text
    name = country.find('d:number', ns).text
    print(name, rank)