xml文件解析
Java对于xml文件解析有四种方法:DOM实现方法,DOM4J实现方法,JDOM实现方法,以及SAX实现方法。
这四种实现方法其原理基本差不多,都是获取到相应的xml文件,并将xml文件中的元素一 一取出,在进行相应操作。
DOM的缺点:
DOM是一次性将文档中的所有内存读取到内存中,如果是文档比较小,在读入内存时能够提高操作速度,但是当文档较大时,则读取比较慢了,因此SAX应运而生,他不是一次性将整个文档读取到内存中的,这对于处理大型文档就方便快捷了。
我就写个DOM的实现方法,其他三种均可根据API来逐步实现:
package cn.test.com;
import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
//将xml文件转换成DOM文件
public class XMLReaderTest {
public static void main(String[] args) {
Document document = null;
Element element = null;
DocumentBuilder documentBuilder = null;
DocumentBuilderFactory factory = null;
try {
//获取文件路径
File xmlFile = new File("test.xml");
//实例化DocumentBuilderFactory对象
factory = DocumentBuilderFactory.newInstance();
//通过工厂生成DocumentBuilder对象
documentBuilder = factory.newDocumentBuilder();
//将XML文件转换成DOM文件
document = documentBuilder.parse(xmlFile);
//获取DOM文件根元素
element = document.getDocumentElement();
//获取根元素下的所有子节点
NodeList nodeList = element.getChildNodes();
//遍历子节点
for(int i=0;i<nodeList.getLength();i++){
Node node = nodeList.item(i);
//获取该节点的所有属性
NamedNodeMap map = node.getAttributes();
//遍历所有属性
if(map!=null&&map.getLength()>0){
for(int j=0;j<map.getLength();j++){
Node attribute = map.item(j);
//输出属性值
if("id".equalsIgnoreCase(attribute.getNodeName())){
System.out.println("id:"+attribute.getNodeValue());
}else if("class".equalsIgnoreCase(attribute.getNodeName())){
System.out.println("class:"+attribute.getNodeValue());
}
}
}
//获取该节点的所有子节点
NodeList nodeList2 = node.getChildNodes();
//遍历该节点的所有子节点
for(int j=0;j<nodeList2.getLength();j++){
Node subNode = nodeList2.item(j);
//输出节点的文本内容
if("test".equalsIgnoreCase(subNode.getNodeName())){
System.out.println("test:"+subNode.getTextContent());
}else if("property".equalsIgnoreCase(subNode.getNodeName())){
System.out.println("property:"+subNode.getTextContent());
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
test.xml文件:
<?xml version="1.0" encoding="UTF-8"?>
<beans>
<bean id="test" class="cn.test.com.ReflectTest">
<test>test 1</test>
<property>perperty 1 </property>
</bean>
</beans>
通过xml解析,以及反射我们就可以实现一个简单的框架应用了