Dom生成Xml和解析Xml
xml这种文件格式在很多时候都是很适合我们用来存取数据的,所以利用程序来生成xml文件和解析xml文件就显得比较重要了。在dom中是把每一个元素都看做是一个节点Node的,所有页面上的属性、元素等都是继承自Node的,所以当获取到的是一个Node,而你知道它实际的类型并需要使用的时候就可能会需要进行类型转换了。
Element root = document.getDocumentElement();//获取根节点
下面是代码:
生成xml:
![](http://haohaoxuexi.iteye.com/images/icon_star.png)
- 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");
- for (int i=0;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文件是这个样子
![](http://haohaoxuexi.iteye.com/images/icon_star.png)
- <?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的编码,或者输出形式等。
![](http://haohaoxuexi.iteye.com/images/icon_star.png)
- transformer.setOutputProperty("encoding", "UTF-8");//设定文档编码,属性也可以使用OutputKeys的静态常量属性设定
- transformer.setOutputProperty(OutputKeys.METHOD, "xml");//输出方式,可以是xml、html和text
下面的解析也是基于这个文件的。
解析xml:
![](http://haohaoxuexi.iteye.com/images/icon_star.png)
- 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");
- for (int i=0;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()
- String name = person.getElementsByTagName("name").item(0).getTextContent();
- String address = person.getElementsByTagName("address").item(0).getTextContent();
- String email = person.getElementsByTagName("email").item(0).getTextContent();
- System.out.println(" id = "+id+" \r\n name = "+name+" \r\n address = "+address+" \r\n email = "+email);
- System.out.println("-------------------------------------");
- }
- }
解析后输出的结果:
![](http://haohaoxuexi.iteye.com/images/icon_star.png)
- 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相关推荐
- JavaScript解析XML,js解析xml字符串
XMl 可扩展的文本标记语言,用来传输数据和保存数据 整个文档是一个文档节点 每个XMl标签是一个元素节点 包含在xml标签内的文本是文本节点 每个xml属性是一个属性节点 注释属于一个注释节点XML ...
- python解析xml生成代码_python解析xml模块封装代码
有如下的xml文件: 复制代码 代码如下: 1 2 下面介绍python解析xml文件的几种方法,使用python模块实现. 方式1,python模块实现自动遍历所有节点: 复制代码 代码如下: #! ...
- Java使用DOM和DOM4J分别解析XML文件步骤以及代码
XML文件如下: PhoneType.xml <?xml version="1.0" encoding="UTF-8" standalone=" ...
- Java菜鸟补给站--HTML,XML,以及解析XML
目录 HTML,XML的区别 解析XML DOM解析 SAX解析 选择DOM还是选择SAX? DOM4J解析 JDOM解析 HTML,XML的区别 1. XML是区分大小写字母的,HTML不区分. 2 ...
- 【4-8】《XML与JSON》——XML、解析XML、SAX、DOM4J、XStream、JSON、Gson、Fastjson
文章目录 XML与JSON 一.XML 1.XML概述 1.XML语法格式 2.语法进阶CDATA(了解) 2.解析XML 1.SAX解析 2.DOM解析 3.JDOM解析 4.DOM4J解析 3.D ...
- php 解析返回的xml,php解析xml的几种方式
php提供几种解析xml的类或方法,包括:Xml parser. SimpleXML,.XMLReader,.DOMDocument. XML Expat Parser: XML Parser使用Ex ...
- jdom 组装xml以及解析xml
[java] view plaincopy 到官方网站下载JDOM包http://www.jdom.org/ [java] view plaincopy 注意的是,版本1和版本2的类路径已经变更,如果 ...
- java解析xml element_java解析XML Node与Element的区别(推荐)
对Element和Node有困惑是因为对xml整个结构不了解,以下作为一个简要概述: 以下图为w3c.org网站的xml文档树图: 从上图可以看出,一个xml文档由元素节点,属性节点,文本节点构成,其 ...
- tinyxml2 数组_7.数据本地化CCString,CCArray,CCDictionary,tinyxml2,写入UserDefault.xml文件,操作xml,解析xml...
数据本地化 A CCUserDefault 系统会在默认路径cocos2d-x-2.2.3\projects\Hello\proj.win32\Debug.win32下生成一个名为UserDef ...
最新文章
- 语义分割车道线,来自两篇论文的融合算法
- Java接地气日常编码技巧
- mysql udf提权_mysql——udf提权
- Spring事物详解和传播行为
- GDCM:gdcm::ServiceClassUser的测试程序
- 判断字符串中是否为数字的三种方法
- photoshop问题
- 【pandas】删除满足条件元素所在的行
- FreeSwitch的Canvas功能
- 在函数‘_start’中:对‘main’未定义的引用
- 局域网攻击之ARP网关欺骗
- Cesium加载OSGB数据
- 计算机博士职业规划,博士职业生涯规划
- U盘winpe启动盘的制作
- 爬虫之巨潮资讯网关键词信息获取
- 订单管理_03查询订单信息流程
- STM32F407 FSMC驱动MT29F4G08A NAND FLASH源代码分享
- 使用EggJS开发接口(三)登录验证之egg-jwt 及 crypto加密
- Cravatar头像
- 信号之零输入和零状态响应