python - 在Python的另一个类ElementTree中继续解析

标签 python xml parsing elementtree xml.etree

在我的第一个类中,我像这样解析我的 xml 文件:

class ListActeurs():
    fonction_key = "DiagramElements"
    def __init__(self):

         self.list_acteurs = []

         root = ElementTree.parse("D:\\Users\T0211254\MyApp\Bundle CUD-CAPELLA 431\melody\eclipse\workspace\XML2\XML2.aird").getroot()
         for diagram in self.root:
             if ListActeurs.diagramme_key in diagram.tag:
                self.diagram_name = diagram.attrib.get('name')
                self.diagram_id = diagram.get('{http://www.omg.org/XMI}id')
                self.dict_diagrams[self.diagram_name] = self.diagram_id
                for owned in diagram:
                    if ListActeurs.acteur_key in owned.tag:
                        self.acteur_name = owned.attrib.get('name')  # Récupération des noms des acteurs
                        self.acteur_id = owned.get('{http://www.omg.org/XMI}id')  # Récupération des id's des acteurs
                        print(self.acteur_name, '==>', self.acteur_id)
                        for elements in owned:
                            if ListActeurs.fonction_key in elements.tag:
                                self.fonctions_name = elements.attrib.get('name')  # Récupération des noms des fonctions
                                self.fonctions_id = elements.get('{http://www.omg.org/XMI}id')  # Récupération des ID's des fonctions
                                self.data_fonctions = ElementTree.tostring(elements)
                                self.list_acteurs.append(Acteur(self.fonctions_name, self.fonctions_id, self.data_fonctions))

最后,我创建了一个具有不同属性的 Object Acteur(),其中包括“self.data_fonction”,其中包含字符串变量中的 xml 文件的一部分。

我想在另一个类中继续解析这部分xml。我试过这个:

class Acteur() :

def __init__(self, fonctions_name, fonctions_id, data_fonctions):

    self.fonctions_name = str(fonctions_name)
    self.fonctions_id = str(fonctions_id)
    self.data_fonctions = str(data_fonctions)
    elements = ET.ElementTree(ET.fromstring(data_fonctions))
    for ports in elements :
        ports_name = ports.attrib.get('name')
        print(ports_name)

但是有一个错误:

for ports in elements :
TypeError: 'ElementTree' object is not iterable

但是我无法使用 ElementTree 函数 parse() 因为它不再是一个文件。我怎样才能做到这一点 ?我正在考虑创建一个 xml 文件并将“self.data_fonction”放入其中以解析此 xml 文件,但是有没有更好的方法来执行此操作?

谢谢

最佳答案

根据文档:https://docs.python.org/2/library/xml.etree.elementtree.html

在解析 xml 文件时,您创建了 ElementTree 对象。 您必须使用 ElementTree 对象的实例(代码示例中的“root”)才能进行迭代。

所以基本上只需使用:

for child in root:
    print child.tag, child.attrib

而不是:

elements = ET.ElementTree(ET.fromstring(data_fonctions))
for ports in elements :
    ports_name = ports.attrib.get('name')
    print(ports_name)

关于python - 在Python的另一个类ElementTree中继续解析,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55300102/

相关文章:

python - 使解码后的 MVT 转为人类可读的 TEXT

python - 不要使用 json.dumps 引用某些字符串

xml - 定义一个必须为空且没有属性的 XML 元素

XML 解析 Golang

python - 变压器 : cannot import name 'AutoModelWithLMHead' from 'transformers'

python - 在 python 扩展 (.so) 中同时链接 libgfortran 和 libstdc++

java - 没有运行第一个 Activity

python - 使用python将字符串转换为字典

parsing - 帮助理解LR(1)解析器,生成表吗?还有其他资源吗?

Python - 如何使用 xml.etree.ElementTree 迭代每个 xml 节点返回列表?