Dom生成Xml和解析Xml
xml这样的文件格式在非常多时候都是非常适合我们用来存取数据的,所以利用程序来生成xml文件和解析xml文件就显得比較重要了。在dom中是把每个元素都看做是一个节点Node的,全部页面上的属性、元素等都是继承自Node的,所以当获取到的是一个Node。而你知道它实际的类型并须要使用的时候就可能会须要进行类型转换了。
Element root = document.getDocumentElement();//获取根节点
以下是代码:
生成xml:
- public void geneXmlByDom() throws Exception {
- //step1:获得一个DocumentBuilderFactory
- DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
- //step2:获得一个DocumentBuilder
- DocumentBuilder db = factory.newDocumentBuilder();
- //step3:新建一个Document对象
- Document document = db.newDocument();
- //step4:创建一个根节点
- Element rootElement = document.createElement("Persons");
- ;i<5;i++) {
- //step5:创建一个节点
- Element person = document.createElement("person");
- //step6:为该节点设定属性
- person.setAttribute("id", "id_"+i);
- Element name = document.createElement("name");
- //为节点设定文本内容
- name.setTextContent("name_"+i);
- Element address = document.createElement("address");
- address.setTextContent("address_"+i);
- Element email = document.createElement("email");
- email.setTextContent("email_"+i);
- person.appendChild(name);
- person.appendChild(address);
- person.appendChild(email);
- //step7:为某一元素节点设立子节点
- rootElement.appendChild(person);
- }
- //step8:把刚刚建立的根节点加入到document对象中
- document.appendChild(rootElement);
- //step9:获得一个TransformerFactory对象
- TransformerFactory transformerFactory = TransformerFactory.newInstance();
- //step10:获得一个Transformer对象
- Transformer transformer = transformerFactory.newTransformer();
- //step11:把document对象用一个DOMSource对象包装起来
- Source xmlSource = new DOMSource(document);
- //step12:建立一个存储目标对象
- Result outputTarget = new StreamResult(new File("persons.xml"));
- //step13:生成对应的xml文件
- transformer.transform(xmlSource, outputTarget);
- }
生成的xml文件是这个样子
- <?
xml version="1.0" encoding="UTF-8" standalone="no"?
>
- <Persons>
- <person id="id_0">
- <name>name_0</name>
- <address>address_0</address>
- <email>email_0</email>
- </person>
- <person id="id_1">
- <name>name_1</name>
- <address>address_1</address>
- <email>email_1</email>
- </person>
- <person id="id_2">
- <name>name_2</name>
- <address>address_2</address>
- <email>email_2</email>
- </person>
- <person id="id_3">
- <name>name_3</name>
- <address>address_3</address>
- <email>email_3</email>
- </person>
- <person id="id_4">
- <name>name_4</name>
- <address>address_4</address>
- <email>email_4</email>
- </person>
- </Persons>
在进行输出写到文件的时候能够设置一些Transformer输出的參数,如xml的编码。或者输出形式等。
- transformer.setOutputProperty("encoding", "UTF-8");//设定文档编码。属性也能够使用OutputKeys的静态常量属性设定
- transformer.setOutputProperty(OutputKeys.METHOD, "xml");//输出方式,能够是xml、html和text
以下的解析也是基于这个文件的。
解析xml:
- public void parseXmlByDom() throws Exception {
- //step1:获得DocumentBuilderFactory
- DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
- //step2:获得DocumentBuilder
- DocumentBuilder db = factory.newDocumentBuilder();
- //step3:把须要解析的xml文件载入到一个document对象中
- Document document = db.parse("persons.xml");
- //获取全部名称为person的元素
- NodeList nodeList = document.getElementsByTagName("person");
- ;i<nodeList.getLength();i++) {
- //由于这里我知道它就是一个Element对象,所以进行了强转
- Element person = (Element)nodeList.item(i);
- //获得Element对象的属性
- String id = person.getAttribute("id");
- //由于这里我知道仅仅有一个对象,所以就直接item(0)了,
- //由于Dom是把每一个对象都看做是一个节点的,所以假设在item(0)的时候直接取getNodeValue()是取不到值的,
- //仅仅有是TextNode的时候用那个方法才干够取到值,假设想直接取值就用getTextContent()
- ).getTextContent();
- ).getTextContent();
- ).getTextContent();
- System.out.println(" id = "+id+" \r\n name = "+name+" \r\n address = "+address+" \r\n email = "+email);
- System.out.println("-------------------------------------");
- }
- }
解析后输出的结果:
- id = id_0
- name = name_0
- address = address_0
- email = email_0
- -------------------------------------
- id = id_1
- name = name_1
- address = address_1
- email = email_1
- -------------------------------------
- id = id_2
- name = name_2
- address = address_2
- email = email_2
- -------------------------------------
- id = id_3
- name = name_3
- address = address_3
- email = email_3
- -------------------------------------
- id = id_4
- name = name_4
- address = address_4
- email = email_4
- -------------------------------------
Dom生成Xml和解析Xml的更多相关文章
- dom4j组装xml 以及解析xml
dom4j组装xml 以及解析xml: 1.下载dom4j的jar包,地址:https://dom4j.github.io/ 2.java代码: package test; import java.i ...
- Android 生成和Pull解析xml
一.单个对象生成xml 生成以下xml,该怎么生成呢? <?xml version='1.0' encoding='UTF-8' standalone='yes' ?> <accou ...
- android 生成、pull解析xml文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools= ...
- 7.数据本地化CCString,CCArray,CCDictionary,tinyxml2,写入UserDefault.xml文件,操作xml,解析xml
数据本地化 A CCUserDefault 系统会在默认路径cocos2d-x-2.2.3\projects\Hello\proj.win32\Debug.win32下生成一个名为UserDef ...
- Python—使用xml.sax解析xml文件
什么是sax? SAX是一种基于事件驱动的API. 利用SAX解析XML文档牵涉到两个部分:解析器和事件处理器. 解析器负责读取XML文档,并向事件处理器发送事件,如元素开始跟元素结束事件; 而事件处 ...
- 基于Woodstox的StAX 2 (Streaming API for XML)解析XML
StAX (Streaming API for XML)面向流的拉式解析XML,速度快.占用资源少,非常合适处理大数据量的xml文件. 详细教程和说明可以参见以下几篇文章: 使用 StAX 解析 XM ...
- SqL读取XML、解析XML、SqL将XML转换DataTable、SqL将XML转换表
DECLARE @ItemMessage XML )) SET @ItemMessage=N' <ReceivablesInfos> <ReceivablesList> < ...
- java生成解析xml的另外两种方法Xstream
Xstream生成和解析xm和JAXB生成和解析xml的方法. 一,Xstream Xstream非jdk自带的,需要到入Xstream-1.4.3.jar和xpp3_min-1.1.4.jar 1. ...
- [java开发篇][dom模块] 遍历解析xml
http://blog.csdn.net/andie_guo/article/details/24844351 XML DOM节点树 XML DOM将XML文档作为树结构,树结构称为一个节点树.所有的 ...
随机推荐
- Cocos2d-x CCTableView实现列表
在ios程序设计中,会大量使用到tableview视图(UITableView),那么在cocos2d-x中,如果需要类似的列表,该如何实现呢?在引擎中参照ios中的UITableView实现了一个叫 ...
- Android组件:Fragment切换后保存状态
之前写的第一篇Fragment实例,和大多数人一开始学的一样,都是通过FragmentTransaction的replace方法来实现,replace方法相当于先移除remove()原来所有已存在的f ...
- MFC:重绘Button,定制CButton,自画CPngButton,求赐教(各种bug包括性能bug)谢谢谢谢
[1.]CPngButton.h(资源是最后图片) #pragma once #include<atlimage.h> #define PNUM 19 #define PLAYTIME 1 ...
- linux: Ubuntu安装samba的问题
Ubuntu安装samba的问题 http://blog.csdn.net/jk110333/article/details/8920841 root@ubuntu:~# apt-get instal ...
- C#游戏框架uFrame
C#游戏框架uFrame兼谈游戏架构设计 c#语言规范 阅读目录 1.概览 2.基本概念 3.依赖注入 4.Manager of Managers 5.利用UniRX实现响应式编程 6.研究总结 回到 ...
- [ACM] n划分数m部分,它要求每一个部分,并采取了最大的产品(间隔DP)
A - 爱管闲事 春希很爱管闲事,他每天都会抽出时间帮助一些同学,因为春希很死板,出于公平性,春希不会先帮助后来找他的同学. 如今有n个同学须要他的帮助,尽管他非常想一天之类帮助全部人,但毕竟精力有限 ...
- gcc configure: error: Building GCC requires GMP 4.2+, MPFR 2.3.1+ and MPC 0.8.0
从svn checkout svn://gcc.gnu.org/svn/gcc/trunk拿了GCC的最新代码,打算编译了学东西习学习C++ 11的东西,结果在configure的时候出现例如以下问题 ...
- 浮点数在计算机内存中的表示(IEEE 754规定1位是符号位,8位是指数,剩下的23位为有效数字)
本文转载自:阮一峰的博客,http://www.ruanyifeng.com/blog/2010/06/ieee_floating-point_representation.html 张玉彬的博客 h ...
- CentOS 6.4 x86_64 安装GCC 4.7.3
下载gcc-4.7.3.tar.gz, 解压缩 wget ftp://ftp.gnu.org/gnu/gcc/gcc-4.7.3/gcc-4.7.3.tar.gz tar -xzvf gcc-4.7. ...
- 14.18.1 The InnoDB Recovery Process InnoDB 恢复进程:
14.18.1 The InnoDB Recovery Process InnoDB 恢复进程: InnoDB crash recovery 有几个步骤组成: 1.应用redo log,Redo lo ...