我正在编写程序,以处理xml文件,并改变它。但是当我试着去了解它的任何部分时,我得到了一些额外的部分。
我的xml文件:
<?xml version="1.0" encoding="UTF-8"?>
<Package xmlns="http://soap.sforce.com/2006/04/metadata">
<types>
<members>sbaa__ApprovalChain__c.ExternalID__c</members>
<members>sbaa__ApprovalCondition__c.ExternalID__c</members>
<members>sbaa__ApprovalRule__c.ExternalID__c</members>
<name>CustomField</name>
</types>
<version>40.0</version>
</Package>我有我的代码:
from lxml import etree
import sys
tree = etree.parse('package.xml')
root = tree.getroot()
print( root[0][0].tag )作为输出,我希望看到成员,但我得到的结果如下:
{http://soap.sforce.com/2006/04/metadata}members为什么我会看到这个url,以及如何阻止它出现?
发布于 2017-10-06 17:34:37
您已经定义了默认命名空间(Wikipedia、lxml tutorial)。定义后,它是每个子标记的一部分。
如果您想打印不带名称空间的标记,这很容易
tag = root[0][0].tag
print(tag[tag.find('}')+1:])如果要从XML中删除命名空间,请参见this question。
https://stackoverflow.com/questions/46601678
复制相似问题