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的基本步骤如下: 1. **导入必要的库**:在Java中,DOM解析功能主要由`javax.xml.parsers`和`org.w3c.dom`包提供。因此,首先需要在代码中导入这些库: ```java import javax.xml.parsers....
本篇文章将详细介绍如何使用DOM(Document Object Model)和DOM4j这两种流行的方法来解析XML文件。 首先,DOM是一种标准的W3C推荐的解析XML的方法,它将整个XML文档加载到内存中,形成一个树形结构,便于程序进行...
文档对象模型 节点和节点树 使用DOM加载XML文档 使用DOM访问、创建和修改节点
在压缩包文件"复件 dom"中,可能包含了示例代码或教程,用于演示如何使用DOM4J和本地DOM解析XML文件。通过查看这些文件,你可以更深入地了解两种方法的具体实现,并在实际项目中选择合适的方式处理XML数据。 总结来...
在这个例子中,我们将深入探讨如何使用DOM解析XML文件,以理解和掌握XML文档的结构,并进行数据提取、修改和创建。 首先,XML(Extensible Markup Language)是一种标记语言,用于存储和传输数据,具有自描述性和...
DOM解析XML和创建XML是Web开发中的基础技能,尤其在处理动态数据和接口交互时,理解并掌握DOM与XML的结合应用至关重要。在实际项目中,我们可能还需要结合其他技术,如XSLT(用于转换XML)和XPath(用于在XML文档中...
学习DOM解析XML对于任何需要处理XML数据的Java开发者都是基础且重要的技能,因为它提供了灵活性和强大的功能来创建、修改和分析XML文档。然而,DOM的缺点是内存占用大,对于大型XML文档,可能需要考虑更轻量级的解析...
使用DOM解析XML文件的步骤如下: 1. 加载XML文件:首先,你需要创建一个`DocumentBuilderFactory`对象,然后通过`newDocumentBuilder()`方法得到一个`DocumentBuilder`实例。接着,调用`parse()`方法,传入XML文件...
这些库提供了创建DOM解析器、解析XML文件和操作XML节点的功能。 ### 3. 实现步骤 #### (1) 导入所需的库 ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; ...
DOM(Document Object Model)是处理XML的一种方法,它将XML文档视为一个树形结构,允许开发者通过节点操作来读取、修改或创建XML内容。在Android 4.0及以上版本,我们可以使用内置的Java XML DOM API来实现XML解析...
本篇文章将深入探讨DOM解析XML文件在Android中的应用实例。 首先,DOM解析的基本思想是将整个XML文件加载到内存中,形成一个树形结构,即DOM树。这样做的优点是解析后的数据可以方便地进行任意位置的查找和修改,但...
在本文中,我们将学习如何使用 Dom4j 生成 XML 文档和解析 XML 文档。 生成 XML 文档 使用 Dom4j 生成 XML 文档非常简单。首先,我们需要创建一个 Document 对象,然后添加元素和属性。下面是一个生成 XML 文档的...
- 解析XML文件: ```java Document doc = builder.parse("path_to_xml_file.xml"); ``` - 创建新的`Document`: ```java Document doc = builder.newDocument(); ``` 4. 在`Document`中创建元素、属性和其他节点: ...
Java DOM 解析 XML 实例 Java DOM 解析 XML 实例是 Java 语言中常用的 XML 解析方法之一,...通过使用 DOM 解析 XML 文档,我们可以轻松地访问和操作 XML 文档中的元素和属性,从而实现了对 XML 文档的解析和处理。
- **读取XML文档**:使用`DocumentHelper.parseText()`或`SAXReader.read()`方法解析XML文本或文件到`Document`对象。 - **遍历元素**:通过`Element`的`elementIterator()`方法获取子元素迭代器。 - **XPath查询...
在Android中,我们通常使用`javax.xml.parsers.DocumentBuilderFactory`来创建解析器,并通过`DocumentBuilder`实例解析XML文件。下面是一个简单的示例: ```java DocumentBuilderFactory factory = ...
使用DOM方法读取XML文件,需要创建DocumentBuilderFactory对象,获取DocumentBuilder对象,然后解析XML文件得到Document对象。最后,使用Document对象的getElementsByTagName方法获取指定标签的节点列表,并遍历节点...
这篇博客()可能详细介绍了如何使用DOM4J来生成和解析XML文件,这对于处理XML文档的开发人员来说是非常有用的工具。 **1. 生成XML文件** 生成XML文件主要涉及以下步骤: - **创建Document对象**:DOM4J通过`...