一、XML简介
XML是可扩展的标记性语言
作用:
1.用来保护数据,而且这些数据具有自我描述性
2.他可以作为项目或者模块的配置文件
3.还可以作为网络传输数据的格式(现在JSON为主)
二、XML语法
1.文档声明:
创建一个xml文件
<?xml version="1.0" encoding="UTF-8" ?>
<!--
<?xml version="1.0" encoding="UTF-8" ?>
以上内容就是xml的声明
version="1.0" 表示xml的版本
encoding="UTF-8" 表示xml本身的编码
-->
<books>
<book sn="SN1"><!--book表示一个图书信息 sn表示图书序列号-->
<name>时间简史</name><!--表示书名-->
<author>霍金</author><!--作者-->
<price>75</price><!--价格-->
</book>
<book sn="SN2"><!--book表示一个图书信息 sn表示图书序列号-->
<name>java从入门到放弃</name><!--表示书名-->
<author>傻老师</author><!--作者-->
<price>9.9</price><!--价格-->
</book>
</books>
2.元素(标签)
1)指的是从开始标签,到结束标签的部分
2)元素的命名规则:
.名称可以包含字母数字与其他字符
.名称不能以数字或者标点符号或字符"xml"开始
.名称不能包含空格
3)元素也分单标签和双标签
3.xml属性
可以提供元素的的额外信息(其规则与标签的书写规则一致)
在标签上可以书写属性;一个标签上可以书写多个属性,每个属性的值必须用引号引起来
4.xml注释
同HTML
5.语法规则
.所有xml元素都必须有关闭标签
.对大小写敏感
.XML必须正确的嵌套
.文档必须有根元素(顶级元素:没有父标签的元素)
.特殊字符特殊符号
.文本区域(CDATA区)
CDATA语法:可以告诉xml解释器,其中的内容时纯文本,不需要xml解析
CDATA格式:
三、解析技术介绍
使用w3c组织制定的dom技术来解析
四、dom4j解析技术
1.Dom4j类库的使用
2.目录介绍
3.编程步骤
第一步: 先加载 xml 文件创建 Document 对象 第二步:通过 Document 对象拿到根元素对象 第三步:通过根元素.elelemts(标签名); 可以返回一个集合,这个集合里放着。所有你指定的标签名的元素对象 第四步:找到你想要修改、删除的子元素,进行相应在的操作 第五步,保存到硬盘上
4.获取 document 对象
创建一个 lib 目录,并添加 dom4j 的 jar 包。并添加到类路径。
<?xml version="1.0" encoding="UTF-8"?>
<books>
<book sn="SN12341232">
<name>辟邪剑谱</name>
<price>9.9</price>
<author>班主任</author>
</book>
<book sn="SN12341231">
<name>葵花宝典</name>
<price>99.99</price>
<author>班长</author>
</book>
</books>
package com.atguigu.pojo;
import java.math.BigDecimal;
public class Book {
private String sn;
private String name;
private BigDecimal price;
public BigDecimal getPrice() {
return price;
}
public String getAuthor() {
return author;
}
public void setAuthor(String author) {
this.author = author;
}
public void setPrice(BigDecimal price) {
this.price = price;
}
private String author;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSn() {
return sn;
}
public void setSn(String sn) {
this.sn = sn;
}
@Override
public String toString() {
return "Book{" +
"sn='" + sn + '\'' +
", name='" + name + '\'' +
", price=" + price +
", author='" + author + '\'' +
'}';
}
}
package com.atguigu.pojo;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.junit.Test;
import java.math.BigDecimal;
import java.util.List;
public class Dom4jTest {
@Test
public void test1() throws Exception {
//创建一个SaxReader输入流,去读取xml配置文件,生成Document对象
SAXReader saxReader = new SAXReader();
Document document = saxReader.read("src/books.xml");
System.out.println(document);
}
@Test
//读取books.xml文件生成的Book类
public void test2() throws Exception {
//1.读取books.xml文件
SAXReader reader = new SAXReader();
//在Junit测试中,相对路径是从模块名开始算
Document document = reader.read("src/books.xml");
//2.通过Document对象获取根元素
Element rootElement = document.getRootElement();
System.out.println(rootElement);
//3.通过根元素获取book标签对象
//element()/elements()都是通过标签名查找子元素
List<Element> books = rootElement.elements("book");
//4.遍历,处理每个book标签转换为Book类
for (Element book : books) {
//asXML()把标签对象转换为标签字符串
// System.out.println(book.asXML());
Element nameElement = book.element("name");
// System.out.println(nameElement.asXML());
//getText();可以获取标签中的文本内容
String nameText = nameElement.getText();
// System.out.println(nameText);
//直接获取指定标签名的文本内容
String priceText = book.elementText("price");
// System.out.println(priceText);
String authorText = book.elementText("author");
System.out.println(authorText);
String snValue = book.attributeValue("sn");
System.out.println(snValue);
}
}
}