-----记录和回顾是一个比学习更重要的环节-----

一、首先,我们需要知道xml是做什么的

1.作为软件的配置文件

2.作为数据的载体(小型的数据库)

二、xml的语法

xml文件以xml后缀名结尾。

xml文件需要使用xml解析器去解析。浏览器内置了xml解析器。

1.标签

语法:<student></student>  开始标签  标签体内容  结束标签

1)<student/> 或 <student></student> 空标签。没有标签体内容

2)xml标签名称区分大小写。

3)xml标签一定要正确配对。

4)xml标签名中间不能使用空格

5)xml标签名不能以数字开头

6)注意: 在一个xml文档中,有且仅有一个根标签

2.属性

语法: <Student name="eric">student</Student>

注意:

1)属性值必须以引号包含,不能省略,也不能单双引号混用!!!

2)一个标签内可以有多个属性,但不能出现重复的属性名!!!

3.注释

语言: <!--  xml注释 -->

4.文档声明

语法: <?xml version="1.0" encoding="utf-8"?>

version: xml的版本号

encoding: 解析xml文件时查询的码表(解码过程时查询的码表)

注意:

1)如果在ecplise工具中开发xml文件,保存xml文件时自动按照文档声明的encoding来保存文 件。

2)如果用记事本工具修改xml文件,注意保存xml文件按照文档声明的encoding的码表来保存,保证xml文件保存的码表和encoding是一致的。

5.转义字符

在xml中内置了一些特殊字符,这些特殊字符不能直接被浏览器原样输出。如果希望把这些特殊字符按照原样输出到浏览器,对这些特殊字符进行转义。转义之后的字符就叫转义字节。

特殊字符  转义字符

<                &lt;

>                &gt;

"                 &quot;

&                 &amp;

空格            &nsbp;

三、dom4j解析xml

DOM解析原理:xml解析器一次性把整个xml文档加载进内存,然后在内存中构建一颗Document的对象树,通过Document对象,得到树上的节点对象,通过节点对象访问(操作)到xml文档的内容。

     /**
* 遍历所有节点
* @throws Exception
*
*/
@Test
public void test2 () throws Exception{
//1.创建一个xml解析器对象
SAXReader saxReader = new SAXReader();
//2.读取xml文档,返回Document对象
Document read = saxReader.read(new File("./src/test.xml"));
Element rootElement = read.getRootElement();
getElement(rootElement);
} private void getElement(Element element){
System.out.println(element.getName());
Iterator<Node> it = element.nodeIterator();
while (it.hasNext()) {
Node node = it.next();
if (node instanceof Element) {
Element element2 = (Element)node;
getElement(element2);
}
}
}

输出结果:

students
student
name
age
student
name
age

获取属性:

     /**
* 获取属性
* @throws Exception
*/
@Test
public void test4() throws Exception{
SAXReader saxReader = new SAXReader();
Document read = saxReader.read(new File("./src/test.xml"));
Element element = read.getRootElement().element("student");
String attributeValue = element.attributeValue("id");
System.out.println(attributeValue);
Attribute idattr = element.attribute("id");
String name = idattr.getName();
System.out.println("name:"+name+"\n"+"value:"+idattr.getValue());
List<Attribute> idattrs = element.attributes();
for(Attribute attribute : idattrs){
System.out.println("name:"+attribute.getName()+" value:"+attribute.getValue());
}
}

获取单标签

     @Test
public void test3() throws Exception{
//1.读取xml文件
SAXReader saxReader = new SAXReader();
Document read = saxReader.read(new File("./src/test.xml"));
Element rootElement = read.getRootElement();
/* System.out.println("rootElement:"+rootElement.getName());
Element element = rootElement.element("student");
System.out.println("element:"+element.getName());
Iterator<Element> elemIt = rootElement.elementIterator("student");
while(elemIt.hasNext()){
Element next = elemIt.next();
System.out.println(next.getName());
}*/
List<Element> elements = rootElement.elements();
//list的三种遍历方式1.普通遍历2.强化for循环3.迭代器
//1.list的普通遍历
/* for(int i = 0 ;i < elements.size();i++)
{
Element element = elements.get(i);
System.out.println(element.getName());
}*/
//2.list的强化遍历
/* for(Element element :elements){
System.out.println(element.getName());
}*/
//3.迭代器
/* Iterator<Element> it = elements.iterator();
while(it.hasNext()){
Element next = it.next();
System.out.println(next.getName());
}*/
Element nameelement = read.getRootElement().element("student").element("name");
System.out.println(nameelement.getName());
}

获取文本

     @Test
public void test5() throws Exception{
SAXReader saxReader = new SAXReader();
Document read = saxReader.read(new File("./src/test.xml"));
String text = read.getRootElement().element("student").element("name").getText();
System.out.println(text);
}

demo:将test.xml文件中的内容封装在类中

test.xml

 <?xml version="1.0" encoding="utf-8"?>
<students>
<student id = "001">
<name>张三</name>
<age>20</age>
</student>
<student id = "002">
<name>李四</name>
<age>25</age>
</student>
</students>

StudentTest.java

 package xmlRead;

 public class StudentTest {
public String id;
public String name;
public String age;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
} @Override
public String toString() {
return "id:"+this.id +" name:"+this.name+" age:"+this.age;
}
}

readStudent类

 public class ReadStudent {
public static void main(String[] args) throws Exception {
SAXReader saxReader = new SAXReader();
Document doc = saxReader.read(new File("./src/test.xml"));
Element rootElement = doc.getRootElement();
Iterator<Element> eleIt = rootElement.elementIterator();
while (eleIt.hasNext()) {
Element element = eleIt.next();
StudentTest student = new StudentTest();
student.setId(element.attributeValue("id"));
student.setName(element.elementText("name"));
student.setAge(element.elementText("age"));
System.out.println(student.toString());
}
}
}

输出结果:

id:001  name:张三     age:20
id:002 name:李四 age:25

读取一个完整的test.xml文件(仅读内容)

 /**
* 读取一个完整的xml文件。
* @author ihome
*
*/
public class readXMl {
@Test
public void test() throws Exception{
SAXReader saxReader = new SAXReader();
Document read = saxReader.read(new File("./src/test.xml"));
Element rootElement = read.getRootElement();
StringBuffer sBuffer = new StringBuffer();
getElementCild(rootElement,sBuffer);
System.out.println(sBuffer.toString());
}
private void getElementCild(Element element,StringBuffer sBuffer){
sBuffer.append("<"+element.getName());
List<Attribute> attributes = element.attributes();
for(Attribute attribute:attributes){
sBuffer.append(" "+attribute.getName()+" = "+attribute.getValue());
}
sBuffer.append(">");
sBuffer.append(element.getText());
Iterator<Element> eleIt = element.elementIterator();
while(eleIt.hasNext()){
Element next = eleIt.next();
getElementCild(next,sBuffer);
}
sBuffer.append("</"+element.getName()+">");
}
}

dom4j读取xml的更多相关文章

  1. 使用dom4j读取xml连接数据库与之单例模式

    使用dom4j读取xml ,加入jar包 dom4j-1.6.1.jar jaxen-1.1-beta-6.jar public class XmlConfigReader { //懒汉式,延迟加载 ...

  2. RSS阅读器(一)——dom4j读取xml(opml)文件

    接触java不久,偶有收获,最近想做一个web版RSS阅读器来锻炼一下.手头有几个从不同版本的foxmail中导出的opml文件,大家应该都知道,opml文件就是xml格式的.那么就先从这里入手,练习 ...

  3. 使用dom4j 读取XML文件

    第一次接触dom4j的时候,感觉这个东西很神秘,因为之前虽然知道XML文件吧,但从来没有用过,一直感觉XML肯定不好操作.当得知,dom4j可以很容易的操作读取XML文件时,不免有些好奇,那么,用do ...

  4. DOM4J读取XML文件

    最近在做DRP的项目,其中涉及到了读取配置文件,用到了DOM4J,由于是刚开始接触这种读取xml文件的技术,好奇心是难免的,于是在网上又找了一些资料,这里就结合找到的资料来谈一下读取xml文件的4中方 ...

  5. Java使用dom4j读取xml时报错:org.dom4j.DocumentException: Error on line 2 of document : Invalid byte 2 of 2-byte UTF-8 sequence. Nested exception: Invalid byte 2 of 2-byte UTF-8 sequence

    1.Java使用dom4j读取xml时报错: org.dom4j.DocumentException: Error on line 2 of document  : Invalid byte 2 of ...

  6. 【XML】利用Dom4j读取XML文档以及写入XML文档

    Dom4j简介 dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的.dom4j是一个十分优秀的JavaXML API,具有性能优异.功能强大和极其易使用的特点,它的性能 ...

  7. java DOM4J 读取XML

    最近学习Java,在处理XML文档的时候,查阅相关资料,发现了DOM4J这个jre库,相对C#的XML处理来说,功能还算是跟得上 下面展示一篇我自己写的一个XML读取测试 import java.ut ...

  8. dom4j 读取xml

    package core.util; import java.io.File; import java.util.Iterator; import java.util.List; import org ...

  9. DOM4J 读取XML配置文件进行数据库连接

        介绍介绍DOM4J.    据说是非常优秀非常优秀的Java XML  API(Dom4j is an easy to use, open source library for working ...

随机推荐

  1. Yii2.0源码阅读-从路由到控制器

    之前的文章弄清了一次请求的开始到结束.主要讲了Yii Applicaton实例的创建.初始化,UrlManager如何返回Yii中的路由信息,到runAction,最后将Response发送给客户端. ...

  2. flask-session组件

    简介 flask-session是flask框架的session组件,由于原来flask内置session使用签名cookie保存,该组件则将支持session保存到多个地方,如: redis mem ...

  3. 使用TensorFlow中的Batch Normalization

    问题 训练神经网络是一个很复杂的过程,在前面提到了深度学习中常用的激活函数,例如ELU或者Relu的变体能够在开始训练的时候很大程度上减少梯度消失或者爆炸问题.但是却不能保证在训练过程中不出现该问题, ...

  4. Mac效率:配置Alfred web search

    // 这是一篇导入进来的旧博客,可能有时效性问题. 想用搜索引擎搜东西,或者查字典时,一般的workflow是:打开浏览器-->打开搜索引擎/字典网站-->输入搜索关键字-->回车. ...

  5. Progressive Web Applications

    Progressive Web Applications take advantage of new technologies to bring the best of mobile sites an ...

  6. 【HTML_标签大全】

    HTML标签大全 标签 描述 标签类型 备注 <!--...--> 定义注释 / 单标签 <!DOCTYPE> 定义文档类型 / 单标签 <head></he ...

  7. deeplearning.ai 神经网络和深度学习 week4 深层神经网络 听课笔记

    1. 计算深度神经网络的时候,尽量向量化数据,不要用for循环.唯一用for循环的地方是依次在每一层做计算. 2. 最常用的检查代码是否有错的方法是检查算法中矩阵的维度. 正向传播: 对于单个样本,第 ...

  8. CTF---Web入门第九题 FALSE

    FALSE分值:10 来源: iFurySt 难度:易 参与人数:4567人 Get Flag:2144人 答题人数:2157人 解题通过率:99% PHP代码审计 hint:sha1函数你有认真了解 ...

  9. [bzoj1819] [JSOI]Word Query电子字典

    正解是trie树...在树上跳来跳去什么的 然而在企鹅qq那题的影响下我写了hash... 添加一个字母到一个串,就相当于另一个串删对应位置上的字母. 改变某个位置上的字母,就相当于两个字符串删掉同一 ...

  10. 树形dp总结

    转自 http://blog.csdn.net/angon823 介绍 1.什么是树型动态规划 顾名思义,树型动态规划就是在"树"的数据结构上的动态规划,平时作的动态规划都是线性的 ...