摘自慕课网
xml dom 定义了访问和处理xml文档的标准方法。
获取xml文件内容的四种解析方式:DOM SAX DOM4J JDOM
基础方法:DOM(平台无关的官方解析方式)、SAX(基于事件驱动的解析方式)
扩展方法:JDOM、DOM4J(在基础的方法上扩展出的,只有在java中能够使用的解析方法)
DOM4J 解析 xml 文件
1、创建一个 SAXReader 对象
SAXReader saxReader = new SAXReader();
2、将 xml 文件加载到 SAXReader 中,并获取 document 对象
Document document = saxReader.read(fileName);
3、通过 getRootElement() 获取根节点元素
Element employeeRoot = document.getRootElement();
4、通过 elementIterator() 获取子节点元素,返回 Iterator 返回迭代器
Iterator eles = eleRoot.elementIterator();
5、通过 while 遍历迭代器
while(eles.hasNest()){
Element ele = (Element)eles.next();}
6、获取属性节点类似 JDOM 解析
List<Attribute> attrs = ele.attributes();
7、获取元素节点名、值
ele.getName() ele.getStringValue()/ele.getText()
8、获取属性节点名、值
ele.getName() ele.geValue()
DOM4J 创建 xml 文件
使用DOM4J创建XML文件中rss根节点步骤
1,创建Document对象,代表着整个XML文档Document do = DocumentHelper.createDocument();
2,创建根节点rss
Element rss = do.addElement("rss");
3,向rss根节点中添加version属性
rss.addAttribute("version","2.0");
4,创建XML文档的输出流
File file = new File("xxx");
XMLWriter writer = new XMLWriter(new FileOutputStream(file));
5,将程序所写的XML文档内容与输出流联系起来
writer.write(do);
6,关闭资源
writer.close();
使用DOM4J生成XML文件中节点以及节点内容的步骤
1,使用根节点对象得到子节点对象
Element ele1 = rss.addElement("String");
2,设置子节点文本内容
ele1.setText("String");
3,设置生成的XML文档的格式
OutputFormat format = OutputFormat.creatPrettyPrint();
这个format对象默认为标准格式,需要其他格式可以调用该对象的其他方法如:
format.setEncoding("GBK");
4,将设置同步到XML文档
Writer write = new Writer(new FileOutputStream(file),format);
优缺点对比
DOM:一次性将整个xml文件加载到内存中,形成DOM树
优点:形成了树结构,直观好理解,代码更容易编写
解析过程中树结构保留在内存中,方便修改
缺点:当xml文件较大时,对内存消耗比较大,容易影响解析性能并造成内存溢出
优点:采用事件驱动模式,对内存消耗比较小
适用于只需要处理xml中数据时
缺点:不易编码
很难同时访问同一个xml中的多处不同数据
JDOM:仅使用具体类而不使用接口
API大量使用了Collections类
DOM4J:JDOM的一种智能分支,它合并了许多超出基本XML文档表示的功能
DOM4J使用接口和抽象基本类方法,是一个优秀的Java XML API
具有性能优异、灵活性好、功能强大和极端易使用的特点
是一个开放源代码的软件
关于dom4j有个博主写的很详细http://blog.csdn.net/redarmy_chen/article/details/12969219