XML文件解析
来源:互联网 发布:软件开发包括哪些 编辑:程序博客网 时间:2024/06/07 03:51
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解析,以及反射我们就可以实现一个简单的框架应用了
0 0
- XML----SAX解析XML文件
- XML---DOM4J解析XML文件
- XML DOM解析XML文件
- XML SAX解析xml文件
- XML jDOM解析XML文件
- XML DOM4J解析XML文件
- 解析XML文件___SAX解析
- java 解析 xml文件
- XML文件解析
- XML文件解析
- JstL解析XML文件
- xml文件解析办法
- DOM解析XML文件
- XML文件解析心得
- xml文件解析-SAX
- xml文件解析-DOM
- xml文件解析-JDOM
- xml文件解析-DOM4J
- Unix高级编程-文件和目录
- Task和Activity回退栈详解
- 【object detection】R-cnn论文笔记
- jquery中html、val与text三者属性取值的联系与区别介绍
- c++ 响铃
- XML文件解析
- spring动态创建切换数据源动态之原理
- SVN分支/合并原理及最佳实践
- Linux配置LNMP环境搭建
- java 枚举
- HDU 5280 Senior's Array(DP思想 暴力)
- Mybatis中updateByPrimaryKeySelective和updateByPrimaryKey区别
- python 与sqlite3
- DAO和DTO的区别