感谢你的路过,希望学生的笔记能给你一点微不足道的参考(2/100)
Java基础思维导图,完整Java体系的链接
一,XML介绍
1.1简介:
可扩展标记语言(eXtensible Markup Language)。 特性: 1. xml具有平台无关性, 是一门独立的标记语言. 2. xml具有自我描述性
1.2为什么学习XML?
1. 网络数据传输
2. 数据存储
3. 配置文件
1.3XML文件
XML文件是保存XML数据的一种方式 XML数据也可以以其他的方式存在(如在内存中构建XML数据)。 不要将XML语言狭隘的理解成XML文件
二,XML语法格式
2.1XML文档声明
<?xml version=“1.0” encoding=“UTF-8”>
2.2标记 ( 元素 / 标签 / 节点) XML文档,由一个个的标记组成.
语法:
开始标记(开放标记): <标记名称>
结束标记(闭合标记): </标记名称>
标记名称: 自定义名称,必须遵循以下命名规则:
1.名称可以含字母、数字以及其他的字符
2.名称不能以数字或者标点符号开始
3.名称不能以字符 “xml”(或者 XML、Xml)开始
4.名称不能包含空格,不能包含冒号(:)
5.名称区分大小写
标记内容: 开始标记与结束标记之间 ,是标记的内容.
例如 ,我们通过标记, 描述一个人名: 李伟杰
2.3一个XML文档中, 必须有且且仅允许有一个根标记.
2.4标记可以嵌套, 但是不允许交叉.
2.5标记的层级称呼 (子标记, 父标记 , 兄弟标记, 后代标记 ,祖先标记)
例如:
<persons>
<person>
<name>李四</name>
<length>180cm</length>
</person>
<person>
<name>李四</name>
<length>200cm</length>
</person>
</persons>
name是person的子标记.也是person的后代标记
name是persons的后代标记. name是length的兄弟标记.
person是name的父标记. persons是name的祖先标记.
2.6标记名称 允许重复
2.7标记除了开始和结束 , 还有属性.
标记中的属性, 在标记开始时 描述, 由属性名和属性值 组成.
格式: 在开始标记中, 描述属性. 可以包含0-n个属性, 每一个属性是一个键值对! 属性名不允许重复 , 键与值之间使用等号连接, 多个属性之间使用空格分割. 属性值 必须被引号引住.
例子:
2.8注释 注释不能写在文档文档声明前 注释不能嵌套注释
格式:
注释开始: <!--
注释结束:-->
代码:
package com.wyh;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.List;
/**
* xml解析本地文件。
* 读取文件里的xml格式内容,并输出
*/
public class Demo1 {
public static void main(String[] args) throws IOException, DocumentException {
//1. 获取输入流
FileInputStream fis = new FileInputStream("D:\\eclipse-workspace\\C_XX_HeXinLeiKu\\g_XX_ XMLYuJSON\\file\\Demo1.xml");
//2. 创建XML读取对象
SAXReader sr = new SAXReader();
//3. 读取并得到文档对象
Document doc = sr.read(fis);
//4. 通过文档获取根元素
Element root = doc.getRootElement();
//5. 开始解析元素
System.out.println(root.getName());
//操作一波
//Element book = root.element("book");
//Element name = book.element("name");
//System.out.println(name.getText());
List<Element> es = root.elements();
for(int i=0;i<es.size();i++){
Element book = es.get(i);
System.out.println(book.attributeValue("id"));
System.out.println(book.elementText("name"));
System.out.println(book.elementText("info"));
System.out.println("-----------------------------");
}
fis.close();
}
}
package com.wyh;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import java.io.IOException;
import java.io.InputStream;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
/**
* xml解析网络文件。
* 读取文件里的xml格式内容,并输出
*/
public class Demo2 {
public static void main(String[] args) throws IOException, DocumentException {
String phone = "13766540206";
//1. 获取到XML资源的输入流
URL url = new URL("http://apis.juhe.cn/mobile/get?phone="+phone+"&dtype=xml&key=9f3923e8f87f1ea50ed4ec8c39cc9253");
URLConnection conn = url.openConnection(); // 打开连接
InputStream is = conn.getInputStream();
//2. 创建一个XML读取对象
SAXReader sr = new SAXReader();
//3. 通过读取对象 读取XML数据,并返回文档对象
Document doc = sr.read(is)