gpt4 book ai didi

java - 如何在 java 的 org.w3c.dom.Node 中获取 TEXT_NODE 的标记名

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:49:05 24 4
gpt4 key购买 nike

在这个接口(interface)的文档中,它声明文本节点都返回“#text”作为它们的名称,而不是实际的标签名称。但是对于我正在做的事情,标签名称是必要的。

// I'm using the following imports
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.EntityResolver;
import org.xml.sax.InputSource;


// In the .xml input file
<country>US</country> // This is a "text node" .getTextContent()
// returns "US", I need "country" and .getNodeName()
// only returns "#text"

我如何访问标签名称?这一定是可能的,我不介意一个骇人听闻的解决方案。

文档:

http://www.w3schools.com/dom/dom_nodetype.asp

http://www.w3.org/2003/01/dom2-javadoc/org/w3c/dom/Node.html

谢谢。

最佳答案

我认为您误解了所涉及的节点。这个 XML:

<country>US</country>

...包含两个节点:

  • country 元素
  • 文本节点,内容为US

元素不是文本节点,并且文本节点没有元素名称,因为它不是元素。了解这些是不同的节点很重要。我相信这就是您所有困惑的根源。

如果您当前正在查看文本节点,则可以使用 node.getParentNode().getNodeName() 获取元素名称。或者,您可以从元素节点调用 getTextContent()

关于java - 如何在 java 的 org.w3c.dom.Node 中获取 TEXT_NODE 的标记名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17980482/

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