gpt4 book ai didi

java - 为什么这个 java 代码没有正确解析我的 Xml?

转载 作者:数据小太阳 更新时间:2023-10-29 02:49:34 26 4
gpt4 key购买 nike

我已经编写了类来将一些 xml 解析为一个对象,但它无法正常工作,当我尝试获取节点的值时,我得到的是 null 而不是节点的内容。

这是我的类的简化版本,它只对单个节点进行 xml 解析:

import java.io.File;
import java.io.IOException;
import java.util.ArrayList;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.apache.log4j.Logger;
import org.apache.log4j.xml.DOMConfigurator;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

public class XmlReaderCutDown {

private static Logger logger = Logger.getLogger(CtiButtonsXmlReader.class);

public static void testXml(String confFile){
DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
try {
DocumentBuilder docBuilder = docBuilderFactory.newDocumentBuilder();
Document doc = docBuilder.parse(new File(confFile));
doc.getDocumentElement().normalize();
if (logger.isDebugEnabled()){
logger.debug("The root element is " + doc.getDocumentElement().getNodeName());
}

NodeList rows = doc.getElementsByTagName("row");

NodeList topRowButtons = ((Element)rows.item(0)).getElementsByTagName("button");
logger.debug("Top row has " +topRowButtons.getLength() + " items.");
Node buttonNode = topRowButtons.item(0);

NodeList nodeList = ((Element)buttonNode).getElementsByTagName("id");
logger.debug("Node list count for "+ "id" + " = " + nodeList.getLength());
Element element = (Element)nodeList.item(0);
String xx = element.getNodeValue();
logger.debug(xx);
String elementValue = ((Node)element).getNodeValue();
if (elementValue != null) {
elementValue = elementValue.trim();
}
else {
logger.debug("Value was null");
}
logger.debug("Node id = "+ elementValue);

} catch (ParserConfigurationException e) {

logger.fatal(e.toString(),e);
} catch (SAXException e) {
logger.fatal(e.toString(),e);
} catch (IOException e) {
logger.fatal(e.toString(),e);
} catch (Exception e) {
logger.fatal(e.toString(),e);
}

}


public static void main(String[] args){
DOMConfigurator.configure("log4j.xml");

testXml("test.xml");
}
}

这是我的 xml 文件的精简版本:

<?xml version="1.0"?>
<root>
<row>
<button>
<id>this is an id</id>
<action>action</action>
<image-src>../images/img.png</image-src>
<alt-text>alt txt</alt-text>
<tool-tip>Tool tip</tool-tip>
</button>
</row>
</root>

这是日志统计输出的内容:

DEBUG XmlReaderCutDown - 根元素是 root

DEBUG XmlReaderCutDown - 顶行有 1 个项目。

DEBUG XmlReaderCutDown - id = 1 的节点列表计数

调试 XmlReaderCutDown -

调试 XmlReaderCutDown - 值为空

调试 XmlReaderCutDown - 节点 id = null

为什么它没有获取 xml 节点中的文本?

我正在使用 JDK 1.6_10 运行

最佳答案

因为你得到的元素是文本元素的父元素,包含你需要的文本。要访问此元素的文本,您应使用 getTextContent而不是 getNodeValue。

有关详细信息,请参阅 Node 中的表格javadoc.

关于java - 为什么这个 java 代码没有正确解析我的 Xml?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/974709/

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