我無法使用Node.getNodeValue()
,Node.getFirstChild().getNodeValue()
或Node.getTextContent()
獲取文本值。使用Java獲取XML節點文本值DOM
我的XML是像
<add job="351">
<tag>foobar</tag>
<tag>foobar2</tag>
</add>
而我試圖讓標籤值(非文本元素獲取工作正常)。我的Java代碼聽起來像
Document doc = db.parse(new File(args[0]));
Node n = doc.getFirstChild();
NodeList nl = n.getChildNodes();
Node an,an2;
for (int i=0; i < nl.getLength(); i++) {
an = nl.item(i);
if(an.getNodeType()==Node.ELEMENT_NODE) {
NodeList nl2 = an.getChildNodes();
for(int i2=0; i2<nl2.getLength(); i2++) {
an2 = nl2.item(i2);
// DEBUG PRINTS
System.out.println(an2.getNodeName() + ": type (" + an2.getNodeType() + "):");
if(an2.hasChildNodes())
System.out.println(an2.getFirstChild().getTextContent());
if(an2.hasChildNodes())
System.out.println(an2.getFirstChild().getNodeValue());
System.out.println(an2.getTextContent());
System.out.println(an2.getNodeValue());
}
}
}
它打印出
tag type (1):
tag1
tag1
tag1
null
#text type (3):
_blank line_
_blank line_
...
感謝您的幫助。
如果你明確指出了變量'n'目前正好持有的文檔或documentElement,這將有所幫助嗎? – AnthonyWJones 2009-04-21 15:06:06
我已添加'n'聲明部分 – Emilio 2009-04-21 15:14:16