首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用lxml库从xmlns标记中获取奇怪的字符串读取xml

使用lxml库从xmlns标记中获取奇怪的字符串读取xml
EN

Stack Overflow用户
提问于 2017-10-06 16:38:07
回答 1查看 58关注 0票数 1

我正在编写程序,以处理xml文件,并改变它。但是当我试着去了解它的任何部分时,我得到了一些额外的部分。

我的xml文件:

代码语言:javascript
运行
复制
<?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>

我有我的代码:

代码语言:javascript
运行
复制
from lxml import etree
import sys

tree = etree.parse('package.xml')
root = tree.getroot()
print( root[0][0].tag )

作为输出,我希望看到成员,但我得到的结果如下:

代码语言:javascript
运行
复制
{http://soap.sforce.com/2006/04/metadata}members

为什么我会看到这个url,以及如何阻止它出现?

EN

回答 1

Stack Overflow用户

发布于 2017-10-06 17:34:37

您已经定义了默认命名空间(Wikipedialxml tutorial)。定义后,它是每个子标记的一部分。

如果您想打印不带名称空间的标记,这很容易

代码语言:javascript
运行
复制
tag = root[0][0].tag
print(tag[tag.find('}')+1:])

如果要从XML中删除命名空间,请参见this question

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46601678

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档