DOM XML读取一问

sdyqingdao 2010-07-31 01:52:04
我有一个xml文件,使用dom读取,最后的时候老是读取null,源代码和该xml文件如下:

Element root = _doc.getDocumentElement();
NodeList items = root.getElementsByTagName("item");

String[][] data = new String[items.getLength()][5];

for(int i=0; i<items.getLength(); i++){
String[] itemData = new String[5];
Node item = items.item(i);
NodeList properties = item.getChildNodes();
for(int j=0; j<properties.getLength(); j++){
if(properties.item(j).getNodeName().equals("itemid")){
itemData[0] = properties.item(j).getNodeValue(); //可以运行到这一步,但老是返回Null
}
else if(properties.item(j).getNodeName().equals("itemtitle"))
{
itemData[1] = properties.item(j).getNodeValue(); //可以运行到这一步,但老是返回Null
}
else if(properties.item(j).getNodeName().equals("condition"))
{
itemData[2] = properties.item(j).getNodeValue(); //可以运行到这一步,但老是返回Null
}
else if(properties.item(j).getNodeName().equals("targetprice"))
{
itemData[3] = properties.item(j).getNodeValue(); //可以运行到这一步,但老是返回Null
}
else if(properties.item(j).getNodeName().equals("instock"))
{
itemData[4] = properties.item(j).getNodeValue(); //可以运行到这一步,但老是返回Null
}
}
data[i] = itemData;
}


<?xml version="1.0" encoding="UTF-8"?>
<items>
<item>
<itemid>B0015T963C</itemid>
<itemtitle>Kindle Wireless Reading Device, Free 3G, 6" Display, White - 2nd Generation</itemtitle>
<condition>new</condition>
<targetprice>169.99</targetprice>
<instock>no</instock>
</item>
<item>
<itemid>B0009VXBAQ</itemid>
<itemtitle>Wii</itemtitle>
<condition>new</condition>
<targetprice>0</targetprice>
<instock>yes</instock>
</item>
<item>
<itemid>B003O6JJKY</itemid>
<itemtitle>Xbox 360 250GB Console</itemtitle>
<condition>new</condition>
<targetprice>249.99</targetprice>
<instock>no</instock>
</item>
</items>
...全文
102 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
wzx168love 2010-07-31
  • 打赏
  • 举报
回复
package cn.com.csuinfosoft.xml.parse.dom;

import java.io.File;
import java.io.IOException;
import java.text.ParseException;

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

import org.w3c.dom.DOMException;
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 DomXml {

public static void main(String[] args) {
DomXml xml = new DomXml();
xml.method();
}

public void method() {
// 获取文档解析器的工厂
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

try {

// 获取XML文档的解析器
DocumentBuilder db = dbf.newDocumentBuilder();
// 设置错误处理
// db.setErrorHandler(new ParseXMLErrorHandler());
// 解析XML文档
Document doc = db.parse(new File("xx.xml"));
// 通过文档根元素,获取到XML文件的根元素<items>
Element root = doc.getDocumentElement();

NodeList items = root.getElementsByTagName("item");

String[][] data = new String[items.getLength()][5];

for (int i = 0; i < items.getLength(); i++) {
String[] itemData = new String[5];
Node item = items.item(i);
NodeList properties = item.getChildNodes();
for (int j = 0; j < properties.getLength(); j++) {
if (properties.item(j).getNodeName().equals("itemid")) {
itemData[0] = properties.item(j).getTextContent(); // 可以运行到这一步,但老是返回Null[/color]
System.out.println(itemData[0]);
} else if (properties.item(j).getNodeName().equals(
"itemtitle")) {
itemData[1] = properties.item(j).getTextContent(); // 可以运行到这一步,但老是返回Null[/color]
System.out.println(itemData[1]);
} else if (properties.item(j).getNodeName().equals(
"condition")) {
itemData[2] = properties.item(j).getTextContent(); // 可以运行到这一步,但老是返回Null[/color]
System.out.println(itemData[2]);
} else if (properties.item(j).getNodeName().equals(
"targetprice")) {
itemData[3] = properties.item(j).getTextContent(); // 可以运行到这一步,但老是返回Null[/color]
System.out.println(itemData[3]);
} else if (properties.item(j).getNodeName().equals(
"instock")) {
itemData[4] = properties.item(j).getTextContent(); // 可以运行到这一步,但老是返回Null[/color]
System.out.println(itemData[4]);
}


}
data[i] = itemData;

}
} catch (ParserConfigurationException e1) {
e1.printStackTrace();
}

catch (SAXException e2) {
e2.printStackTrace();
} catch (IOException e3) {
e3.printStackTrace();
} catch (DOMException e4) {
e4.printStackTrace();
}
}
}

-------这个可以帮你把所有的值取出来,你结合你具体的需要看看哦!!------------
wzx168love 2010-07-31
  • 打赏
  • 举报
回复
是读取出保存起来数据就可以了吗??
xmx2009 2010-07-31
  • 打赏
  • 举报
回复
不会,帮顶

62,635

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧