gpt4 book ai didi

Java DOM 解析器 : XMI - Inline Tag?

转载 作者:行者123 更新时间:2023-12-02 07:40:11 25 4
gpt4 key购买 nike

我目前正在尝试为一些 XMI 文件(从 UML 图生成)编写一个简单的解析器,但是当我尝试从此代码片段中提取目标 xmi.idref 时遇到一些问题(我想检索连接的元素)对于给定的 Activity ,我已成功检索所有传入/传出边缘):

<UML2:ActivityEdge xmi.id = 'I6bf577d1m1387a6c0ea1mm7dcb' visibility = 'public' is Specification = 'false'>
<UML2:ActivityEdge.target>
<UML2:CallAction xmi.idref = 'I6bf577d1m1387a6c0ea1mm7dda'/>
</UML2:ActivityEdge.target>

我的问题是,当我尝试提取 UML2:CallAction 时,我的程序没有将其检测为元素节点,而是将其检测为文本节点,顺便说一下,文本节点是空的。这是我所做的示例:

Element edge = searchById(doc,"UML2:ActivityEdge",id);
Element group = (Element) edge.getElementsByTagName("UML2:ActivityEdge.target").item(0);
Node target = group.getChildNodes().item(0);
Element targetRef = (Element) target;
Element t = searchById(doc,targetRef.getNodeName(),targetRef.getAttribute("xmi.idref"));
nameList.add(t.getAttribute("name"));

searchById 方法正在工作(我在代码的各个部分使用它),但如果您认为这可能是问题,我会发布它。请注意,我使用 getChildNodes 而不是 getElementsByTagName,因为此边缘的目标可能并不总是 Activity (例如 XOR 连接/合并节点)。确切的错误是:

com.sun.org.apache.xerces.internal.dom.DeferredTextImpl cannot be cast to org.w3c.dom.Element

当我尝试将“目标”转换为元素时...我想这是因为它是一个“内联”标签,但我不知道如何处理它,作为解析的初学者...

感谢您的帮助,

埃尔维

编辑:我尝试用 getElementsByTagName 替换 getChildNodes,它似乎有效...但是,如果有人可以更正上面的代码或至少解释为什么它不能正常工作,那就太棒了。

最佳答案

简而言之,您做出了一个错误的假设:getChildNodes() 仅返回 XML Element;事实并非如此,它还返回其他类型的节点,包括表示您感兴趣的元素之间的空格和换行符的文本节点。

如果你想调用getChildNodes()并处理所有节点,那么你需要循环所有返回的节点,并查看每个节点以确定它是什么类型的节点,并且对其进行相应处理。如果您不想这样做,则可以使用 getElementsByTagName() 之类的替代方法。

关于Java DOM 解析器 : XMI - Inline Tag?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11715367/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com