遍历GraphML(XML)文件并提取所有值
我有一个XML(实际上是GraphML)文件,如下所示:遍历GraphML(XML)文件并提取所有值,xml,python-3.x,loops,graphml,Xml,Python 3.x,Loops,Graphml,我有一个XML(实际上是GraphML)文件,如下所示: <?xml version="1.0" ?> <graphml> <key attr.name="label" attr.type="string" id="label"/> <graph edgedefault="directed" id=""> <node id="0"> <type>p</type&g
<?xml version="1.0" ?>
<graphml>
<key attr.name="label" attr.type="string" id="label"/>
<graph edgedefault="directed" id="">
<node id="0">
<type>p</type>
<label>sshd(3,2)</label>
</node>
<node id="1">
<type>e</type>
<label>user(3)</label>
</node>
</graph>
</graphml>
这给我的是前两个值重复了两次,换句话说:
p sshd(3,2)
p sshd(3,2)
而不是:
p sshd(3,2)
e user(3)
有人能帮忙吗?x在嵌套循环中从未使用过
for child in root:
for x in child:
嵌套循环中从不使用x
for child in root:
for x in child:
您可以一次指定从根节点到
节点
元素的确切路径:
for node in root.findall('graph/node'):
print(node.find('type').text, node.find('label').text)
您可以一次指定从根节点到
节点
元素的确切路径:
for node in root.findall('graph/node'):
print(node.find('type').text, node.find('label').text)
这很有效,谢谢!,但是,它不会检索每个节点的“id”值。我应该把问题说得更清楚。我想返回:0 p sshd(3,2)1 e user(3)只需添加:
node.get('id')
!,但是,它不会检索每个节点的“id”值。我应该把问题说得更清楚。我想返回:0pshd(3,2)1e用户(3)只需添加:node.get('id')