xml这样的文件格式在非常多时候都是非常适合我们用来存取数据的,所以利用程序来生成xml文件和解析xml文件就显得比較重要了。在dom中是把每个元素都看做是一个节点Node的,全部页面上的属性、元素等都是继承自Node的,所以当获取到的是一个Node。而你知道它实际的类型并须要使用的时候就可能会须要进行类型转换了。

Element root = document.getDocumentElement();//获取根节点

以下是代码:

生成xml:

  1. public void geneXmlByDom() throws Exception {
  2. //step1:获得一个DocumentBuilderFactory
  3. DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
  4. //step2:获得一个DocumentBuilder
  5. DocumentBuilder db = factory.newDocumentBuilder();
  6. //step3:新建一个Document对象
  7. Document document = db.newDocument();
  8. //step4:创建一个根节点
  9. Element rootElement = document.createElement("Persons");
  10. ;i<5;i++) {
  11. //step5:创建一个节点
  12. Element person = document.createElement("person");
  13. //step6:为该节点设定属性
  14. person.setAttribute("id", "id_"+i);
  15. Element name = document.createElement("name");
  16. //为节点设定文本内容
  17. name.setTextContent("name_"+i);
  18. Element address = document.createElement("address");
  19. address.setTextContent("address_"+i);
  20. Element email = document.createElement("email");
  21. email.setTextContent("email_"+i);
  22. person.appendChild(name);
  23. person.appendChild(address);
  24. person.appendChild(email);
  25. //step7:为某一元素节点设立子节点
  26. rootElement.appendChild(person);
  27. }
  28. //step8:把刚刚建立的根节点加入到document对象中
  29. document.appendChild(rootElement);
  30. //step9:获得一个TransformerFactory对象
  31. TransformerFactory transformerFactory = TransformerFactory.newInstance();
  32. //step10:获得一个Transformer对象
  33. Transformer transformer = transformerFactory.newTransformer();
  34. //step11:把document对象用一个DOMSource对象包装起来
  35. Source xmlSource = new DOMSource(document);
  36. //step12:建立一个存储目标对象
  37. Result outputTarget = new StreamResult(new File("persons.xml"));
  38. //step13:生成对应的xml文件
  39. transformer.transform(xmlSource, outputTarget);
  40. }

生成的xml文件是这个样子

  1. <?

    xml version="1.0" encoding="UTF-8" standalone="no"?

    >

  2. <Persons>
  3. <person id="id_0">
  4. <name>name_0</name>
  5. <address>address_0</address>
  6. <email>email_0</email>
  7. </person>
  8. <person id="id_1">
  9. <name>name_1</name>
  10. <address>address_1</address>
  11. <email>email_1</email>
  12. </person>
  13. <person id="id_2">
  14. <name>name_2</name>
  15. <address>address_2</address>
  16. <email>email_2</email>
  17. </person>
  18. <person id="id_3">
  19. <name>name_3</name>
  20. <address>address_3</address>
  21. <email>email_3</email>
  22. </person>
  23. <person id="id_4">
  24. <name>name_4</name>
  25. <address>address_4</address>
  26. <email>email_4</email>
  27. </person>
  28. </Persons>

在进行输出写到文件的时候能够设置一些Transformer输出的參数,如xml的编码。或者输出形式等。

  1. transformer.setOutputProperty("encoding", "UTF-8");//设定文档编码。属性也能够使用OutputKeys的静态常量属性设定
  2. transformer.setOutputProperty(OutputKeys.METHOD, "xml");//输出方式,能够是xml、html和text

以下的解析也是基于这个文件的。

解析xml:

  1. public void parseXmlByDom() throws Exception {
  2. //step1:获得DocumentBuilderFactory
  3. DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
  4. //step2:获得DocumentBuilder
  5. DocumentBuilder db = factory.newDocumentBuilder();
  6. //step3:把须要解析的xml文件载入到一个document对象中
  7. Document document = db.parse("persons.xml");
  8. //获取全部名称为person的元素
  9. NodeList nodeList = document.getElementsByTagName("person");
  10. ;i<nodeList.getLength();i++) {
  11. //由于这里我知道它就是一个Element对象,所以进行了强转
  12. Element person = (Element)nodeList.item(i);
  13. //获得Element对象的属性
  14. String id = person.getAttribute("id");
  15. //由于这里我知道仅仅有一个对象,所以就直接item(0)了,
  16. //由于Dom是把每一个对象都看做是一个节点的,所以假设在item(0)的时候直接取getNodeValue()是取不到值的,
  17. //仅仅有是TextNode的时候用那个方法才干够取到值,假设想直接取值就用getTextContent()
  18. ).getTextContent();
  19. ).getTextContent();
  20. ).getTextContent();
  21. System.out.println(" id = "+id+" \r\n name = "+name+" \r\n address = "+address+" \r\n email = "+email);
  22. System.out.println("-------------------------------------");
  23. }
  24. }

解析后输出的结果:

  1. id = id_0
  2. name = name_0
  3. address = address_0
  4. email = email_0
  5. -------------------------------------
  6. id = id_1
  7. name = name_1
  8. address = address_1
  9. email = email_1
  10. -------------------------------------
  11. id = id_2
  12. name = name_2
  13. address = address_2
  14. email = email_2
  15. -------------------------------------
  16. id = id_3
  17. name = name_3
  18. address = address_3
  19. email = email_3
  20. -------------------------------------
  21. id = id_4
  22. name = name_4
  23. address = address_4
  24. email = email_4
  25. -------------------------------------

Dom生成Xml和解析Xml的更多相关文章

  1. dom4j组装xml 以及解析xml

    dom4j组装xml 以及解析xml: 1.下载dom4j的jar包,地址:https://dom4j.github.io/ 2.java代码: package test; import java.i ...

  2. Android 生成和Pull解析xml

    一.单个对象生成xml 生成以下xml,该怎么生成呢? <?xml version='1.0' encoding='UTF-8' standalone='yes' ?> <accou ...

  3. android 生成、pull解析xml文件

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools= ...

  4. 7.数据本地化CCString,CCArray,CCDictionary,tinyxml2,写入UserDefault.xml文件,操作xml,解析xml

     数据本地化 A CCUserDefault 系统会在默认路径cocos2d-x-2.2.3\projects\Hello\proj.win32\Debug.win32下生成一个名为UserDef ...

  5. Python—使用xml.sax解析xml文件

    什么是sax? SAX是一种基于事件驱动的API. 利用SAX解析XML文档牵涉到两个部分:解析器和事件处理器. 解析器负责读取XML文档,并向事件处理器发送事件,如元素开始跟元素结束事件; 而事件处 ...

  6. 基于Woodstox的StAX 2 (Streaming API for XML)解析XML

    StAX (Streaming API for XML)面向流的拉式解析XML,速度快.占用资源少,非常合适处理大数据量的xml文件. 详细教程和说明可以参见以下几篇文章: 使用 StAX 解析 XM ...

  7. SqL读取XML、解析XML、SqL将XML转换DataTable、SqL将XML转换表

    DECLARE @ItemMessage XML )) SET @ItemMessage=N' <ReceivablesInfos> <ReceivablesList> < ...

  8. java生成解析xml的另外两种方法Xstream

    Xstream生成和解析xm和JAXB生成和解析xml的方法. 一,Xstream Xstream非jdk自带的,需要到入Xstream-1.4.3.jar和xpp3_min-1.1.4.jar 1. ...

  9. [java开发篇][dom模块] 遍历解析xml

    http://blog.csdn.net/andie_guo/article/details/24844351 XML DOM节点树 XML DOM将XML文档作为树结构,树结构称为一个节点树.所有的 ...

随机推荐

  1. 解决linux下javac -version和java -version版本显示不一致

    解决linux下javac -version和java -version版本显示不一致 [javascript] view plaincopy [root@localhost usr]# $JAVA_ ...

  2. 《高质量程序设计指南:C++/C语言》面试题整理

    本试题仅用于考查C++/C程序员的基本编程技能.内容限于C++/C常用 语法,不涉及 数据结构. 算法以及深奥的语法.考试成绩能反映出考生的编程质量以及对C++/C的理解程度,但不能反映考生的智力和软 ...

  3. Swift - 使用闭包筛选过滤数据元素

    通常筛选一个数组,通常会在代码的其它地方创建一个函数,然后为数组的每个元素调用它.但这样做会使代码分散在许多地方,不便于阅读.使用闭包就可以将相关代码片断放在一起,使结构逻辑更加清晰. 比如,筛选一个 ...

  4. Android智能手机屏蔽电话与屏蔽安装软件功能

    近期做一些项目.须要对手机进行屏蔽自己的固有的功能.在此记录. Android屏蔽电话功能主要是卸载掉Phone.apk. 屏蔽安装软件功能主要是卸载掉PackageInstall.apk 以下以三星 ...

  5. 【linux】具体芯片MACHINE_START处理

    欢迎转载,转载时需保留作者信息,谢谢. 邮箱:tangzhongp@163.com 博客园地址:http://www.cnblogs.com/embedded-tzp Csdn博客地址:http:// ...

  6. Win7+花生壳6.0+tomcat打做自己的web服务器(搭建自己的网站)(参考)

    链接地址:http://blog.csdn.net/zhu_9527/article/details/23344623?utm_source=tuicool&utm_medium=referr ...

  7. php连接oracle及简单操作

    使你的php支持oracle,按照以下步骤即可: 1.安装php环境,找一下appserv或者xampp,一键安装,很方便 2.把php的ext目录下的php_oci8.dll拷到system32目录 ...

  8. HDU 4424 Conquer a New Region 最大生成树

    给你一颗树 每条边有一个权值 选择一个点为中心 定义S值为中心到其它n-1个点的路径上的最小边权 求全部点S值的和 从大到小排序 每次合并2棵树 设为A集合 B集合 设A集合的最大S值的和为sumA ...

  9. Java 23种设计模式详尽分析与实例解析之三--行为型模式

    Java设计模式 行为型模式 职责链模式 模式动机:职责链可以是一条直线.一个环或者一个树形结构.链上的每一个对象都是请求处理者,职责链模式可以将请求的处理组织成一条链,并使请求链传递,由链上的处理者 ...

  10. Spring3.0 入门进阶(1):从配置文件装载Bean

    Spring 已经盛行多年,目前已经处于3.0阶段,关于Spring的概念介绍性的东西网上已经很多,本系列博客主要是把一些知识点通过代码的方式总结起来,以便查阅. 作为入门,本篇主要介绍Bean的加载 ...