有此XML文件,文件名为:Test1XMLDocument,此文件的路径为(E:/JavaProject/JavaStudy/src/com/xml/Test1XMLDocument.xml)
此XML内容为下:
<?xml version="1.0" encoding="UTF-8"?>
<root>
<people>
<abb>
<name>xiaobai</name>
<age>26</age>
</abb>
<faimly>
<name>pef</name>
<num>3</num>
</faimly>
</people>
</root>
使用JAVA来读取此XML的信息。
首先,我们需要读取此XML文件,我们创建一个DocumentBuilderFactory对象factory。之后在根据此factory创建一个builder对象
。
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
DocumentBuilder builder=factory.newDocumentBuilder();
有了创建好的builder对象,我们就可以把XML文件读入了,这里有3种读入方式,分别为:
1.从文件中:
File file= ...;
Document document = builder.parse(file);
2.从一个URL读取:
URL url= ...;
Document document = builder.parse(url);
3.从一个指定的任意输入流:
InputStream in=...;
Document document = builder.parse(in);
以下代码就是描述XML文件从文件中获取:
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse(new File("E:/JavaProject/JavaStudy/src/com/xml/Test1XMLDocument.xml"));
正确读入XML文件后,我们就可以对此XML文件进行操作了。我们可以使用org.w3c.dom包下的Document接口对其进行控制(关于Document接口提供的方法,可以查看JDK文档)。
现在,我们可以使用document接口下的getDocumentElement()方法来获取此XML文件的根元素,来分析此XML的内容。
具体代码:(这里的document为刚以上代码获取的document实例)
Element root = document.getDocumentElement();
获取了XML文件里的根元素之后,我们就可以来查找此XML的子节点了:
NodeList list = root.getChildNodes();
for (int i = 0; i < list.getLength(); i++) {
Node element = (Node) list.item(i);
System.out.println(element);
}
打印出:
[#text:
]
[people: null]
[#text:
]
这里的输出多出了
[#text:
]
[#text:
]
这里表面此XML文件中有空格,如果把上面的XML文件改成如下形式:
<?xml version="1.0" encoding="UTF-8"?>
<root><people>
<abb>
<name>xiaobai</name>
<age>26</age>
</abb>
<faimly>
<name>pef</name>
<num>3</num>
</faimly>
</people></root>
在次运行,结果将为:
[people: null]
找到原因了,修改代码,去掉空格:
NodeList list = root.getChildNodes();
for (int i = 0; i < list.getLength(); i++) {
Node element = (Node) list.item(i);
//去掉XML里的空格。
if(element instanceof Element ){
System.out.println(element);
}
现在输出:
[people: null]
现在,我们修改以下以上的XML文件:
<?xml version="1.0" encoding="UTF-8"?>
<root>
<people>
<abb>
<name>xiaobai</name>
<age>26</age>
</abb>
<faimly>
<name>pef</name>
<num>3</num>
</faimly>
</people>
<bug>
<name>css</name>
<deep>8</deep>
</bug>
</root>
现在,在执行一下以上的代码:
NodeList list = root.getChildNodes();
for (int i = 0; i < list.getLength(); i++) {
Node element = (Node) list.item(i);
//去掉XML里的空格。
if(element instanceof Element ){
System.out.println(element);
}
现在输出:
[people: null]
[bug: null]
从这里可以看出,我们根据得到的NodeList list的实例,根据item方法进行对list的索引,得到了root下的儿子(子节点)。