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");
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文件是这个样子
<?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");
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("-------------------------------------");
}
}
解析后输出的结果:
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文档 使用DOM访问、创建和修改节点
DOM解析XML 创建XML
JAVA 解析XML和生成XML文档源码。比较全 1.DOM生成和解析XML文档 2.SAX生成和解析XML文档 3.DOM4J生成和解析XML文档 4.JDOM生成和解析XML
Dom4j解析XML文档.doc Dom4j解析XML文档.doc Dom4j解析XML文档.doc Dom4j解析XML文档.doc
Dom4j解析和生成XML文档 Dom4j解析和生成XML文档 Dom4j解析和生成XML文档 Dom4j解析和生成XML文档 Dom4j解析和生成XML文档
dom4j是一种解析XML文档的开放源代码XML框架。本文介绍如何使用包含在dom4j中的解析器创建并修改XML文档。dom4j API包含一个解析XML文档的工具。本文中将使用这个解析器创建一个示例XML文档,然后使用同一个解析器...
支持SAX解析XML文件,DOM解析XML文件,Pull解析器解析XML文件,Pull生成XML文件,JAVA和Kotlin两种语言编写
利用Dom4j生成XML和解析XML
Java DOM 生成XML,对基本的DOM又封装了一层,使操作XML更简单
通过dom4j解析xml,修改xml,自动生成xml文件。使用dom4j模拟解析web.xml配置文件,同时考虑到一个url-pattern和多个url-pattern的情况。
dom4j解析xml文件的压缩包,完整版。对jdom进行了封装。包含源码,jar包以及所需的全部内容。
1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件
dom4j+xpath 解析和创建 xml 文件的简单实例
读取和设置xml配置文件是最常用的操作,试用了几个C++的XML解析器,个人感觉TinyXML是使用起来最舒服的,因为它的API...这个解析库的模型通过解析XML文件,然后在内存中生成DOM模型,从而让我们很方便的遍历这棵XML树。
使用dom4j进行解析XML,通过文档助手创建文档节点。向文档节点中添加根元素节点, 向根元素节点上添加子节点
功能说明:对附件的xml文件进行解析,获取到指定字段。并且可以更新字段、添加和删除字段。 详细介绍请看http://sonicning.blogbus.com/logs/36726735.html
在Python中解析XML文件也有Dom和Sax两种方式,这里先介绍如何是使用Dom解析XML,这一篇文章是Dom生成XML文件,下一篇文章再继续介绍Dom解析XML文件。 在生成XML文件中,我们主要使用下面的方法来完成。 主要方法 1、...
1、XMLDOMDocument类: XML对象文档 ->操作创建或读写(元素、节点、属性、注释)等 2、IXMLDOMNode类:每个元素或节点基本都会有的方法;作为元素和节点的基类调用 3、IXMLDOMAttribute类:就是元素或节点的属性类 4...
NULL 博文链接:https://aa84990.iteye.com/blog/1881734
一个用dom4解析和生成XML的java