可扩展的标记性语言。
作用:
1.保存数据,这些数据具有描述性
student.xml
<students> <student> <id>1</id> <name>华仔</name> </student> <student> <id>2</id> <name>张三</name> </student> </students>
2.还可以作为项目或模块的配置文件
3.还可以作为网络传输数据的格式(现在JSON为主)
1.文档声明
2.元素(标签)
3.xml属性
4.xml注释
5.文本区域(CDATA区)
<?xml version="1.0" encoding="utf-8" ?> <!-- xml文件的声明 version="1.0" xml的版本 encoding="utf-8" xml文件本身的编码 --> <books> <book sn="123"> <name>时间简史</name> <author>霍金</author> <price>75</price> </book> </books>
xml元素指的是从(且包括)开始标签直到(且包括)结束标签的部分
元素可包含其他元素、文本或两者的混合。元素也可以拥有属性。
名称可以含字母、数字以及其他的字符
名称不能以数字或者标点符号开始
名称不能以字符 “xml”(或者 XML、Xml)开始
名称不能包含空格
对大小写敏感
文档必须有根元素(顶级元素),根元素是没有父标签的顶级元素,而且是唯一一个才行。
属性值必须加引号
和html一样
快捷键:大写C+回车/TAB
CDATA格式
不管是html还是xml文件都是标记型文档,都可以使用w3c组织制定的dom技术来解析
document 对象表示的是整个文档(可以是 html 文档,也可以是 xml 文档)
快捷键:sout+回车->System
/** 读取 xml 文件中的内容 */ @Test public void readXML() throws DocumentException { // 需要分四步操作: // 第一步,通过创建 SAXReader 对象。来读取 xml 文件,获取 Document 对象 // 第二步,通过 Document 对象。拿到 XML 的根元素对象 // 第三步,通过根元素对象。获取所有的 book 标签对象 // 第四步,遍历每个 book 标签对象。然后获取到 book 标签对象内的每一个元素,再通过 getText() 方法拿到起始标签和结束标签之间的文本内容 // 第一步,通过创建 SAXReader 对象。来读取 xml 文件,获取 Document 对象 SAXReader reader = new SAXReader(); Documentdocument=reader.read("src/books.xml"); // 第二步,通过 Document 对象。拿到 XML 的根元素对象 Element root = document.getRootElement(); // 打印测试 // Element.asXML() 它将当前元素转换成为 String 对象 // System.out.println( root.asXML() ); // 第三步,通过根元素对象。获取所有的 book 标签对象 // Element.elements(标签名)它可以拿到当前元素下的指定的子元素的集合 List<Element> books = root.elements("book"); // 第四步,遍历每个 book 标签对象。然后获取到 book 标签对象内的每一个元素 for (Element book : books) { // 测试 // System.out.println(book.asXML()); // 拿到 book 下面的 name 元素对象 Element nameElement = book.element("name"); // 拿到 book 下面的 price 元素对象 Element priceElement = book.element("price"); // 拿到 book 下面的 author 元素对象 Element authorElement = book.element("author"); // 再通过 getText() 方法拿到起始标签和结束标签之间的文本内容 System.out.println("书名" + nameElement.getText() + " , 价格:"+priceElement.getText() + ", 作者:" + authorElement.getText()); } }