XML概述:

概念:

可扩展的标记语言。

功能:

  1. 作为数据本地存储的格式。(已淘汰)作为结构化存储的方式,不如数据库效率高。目前一部分移动设备中还在使用。
  2. 作为网络中传输数据的格式。(已淘汰)作为网络传输的格式,在目前以移动互联网为主的环境中,格式太大,所以已被JSON格式替代。
  3. 作为配置文件的格式存储配置信息(主要功能)

语法

文本

内部的数据会忽略特殊字符,原样输出

约束



定义xml文档中可以出现的标签、属性及取值范围等限制条件

作用:

开发阶段,我们都是引入别人写好的约束文件使用。

报错:当我们编写或属性写错时可以有友好的提示

开发时的代码提示:提升开发效率。

约束分类:

dtd(逐渐淘汰)老牌的约束技术,有独立的语法。限制规则比较少

schema(新兴)在约束文档中

约束文档:



xmlns:xsd="http://www.w3.org/2001/XMLSchema"定义当前文档为约束文档,可以指定约束的规则

targetNamespace目标名称空间, 用于指定当前文档的名称空间。类似于java代码中的package关键字。

此处一旦定义了名称空间,那么在实例文档中引入当前约束文件时,必须指定该名称空间。

实例文档:



xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"定义当前文档为实例文档,表示当前文档是被约束的,使用约束文件

xsi:schemaLocation="http://shinnippori.lofter.com/xml Aniki.xsd"引入名称空间http://shinnippori.lofter.com/xml,

实例文档中,除了w3c的约束之外,第三方自定义的约束,必须指定约束文件的地址Aniki.xsd(这里恰好是在一层目录内)。

格式:在schemaLocation中,依次编写key和value,key为名称空间的全名,value为约束文件的路径

如:

这里的名称空间/命名空间http://shinnippori.lofter.com/xml不是URL,是URI。

xml为了避免元素冲突,可以给元素加一个特别的前缀,但是必须给这个前缀定义一个命名空间,也就是必须用xmlns属性给这个前缀加一个特别的名字。这个名字必须是个URI。解析器不会用这个URI来查找信息,所以它可以是没有意义的,但实际上企业通常把命名空间指向一个真的含有相关信息的网址。

并可以为该名称空间起一个别名。xmlns:Shinnippori="http://shinnippori.lofter.com/xml"

一个xml中可以引入多个约束文件。类似于java中的import

一个xml中,最多可以有一个名称空间可以省略别名的定义。

解析:操作xml文档,将文档中的数据读取到内存中

操作xml文档

  1. 解析(读取):将文档中的数据读取到内存中
  2. 写入:将内存中的数据保存到xml文档中。持久化的存储

解析xml的方式:

DOM:将标记语言文档一次性加载进内存,在内存中形成一颗dom树



优点:操作方便,可以对文档进行增删改查的所有操作,速度比较快

缺点:占用内存比较多,并不适用于内存比较紧张的环境。

SAX:逐行读取,基于事件驱动的。



优点:占用内存非常少,每次只加载一行数据

缺点:只能读取,不能增删改,速度比较慢

实际上,很多xml解析的工具,在实现时,会同时采用这两种解析方式

xml常见的解析器:

1. JAXP:sun公司提供的解析器,支持dom和sax两种思想

2. DOM4J:一款非常优秀的解析器

3. Jsoup:jsoup 是一款Java 的HTML解析器,可直接解析某个URL地址、HTML文本内容。它提供了一套非常省力的API,可通过DOM,CSS以及类似于jQuery的操作方法来取出和操作数据。

4. PULL:Android操作系统内置的解析器,sax方式的。

Jsoup使用步骤:

  1. 导入jar包
  2. 获取Document对象
  3. 获取对应的标签Element对象
  4. 获取数据

    代码:
			//2.1获取student.xml的path
String path = JsoupDemo1.class.getClassLoader().getResource("student.xml").getPath();
//2.2解析xml文档,加载文档进内存,获取dom树--->Document
Document document = Jsoup.parse(new File(path), "utf-8");
//3.获取元素对象 Element
Elements elements = document.getElementsByTag("name"); System.out.println(elements.size());
//3.1获取第一个name的Element对象
Element element = elements.get(0);
//3.2获取数据
String name = element.text();
System.out.println(name);

对象的使用:

			1. Jsoup:工具类,可以解析html或xml文档,返回Document
* parse:解析html或xml文档,返回Document
* parse​(File in, String charsetName):解析xml或html文件的。
* parse​(String html):解析xml或html字符串
* parse​(URL url, int timeoutMillis):通过网络路径获取指定的html或xml的文档对象
			2. Document:文档对象。代表内存中的dom树
* 获取Element对象
* getElementById​(String id):根据id属性值获取唯一的element对象
* getElementsByTag​(String tagName):根据标签名称获取元素对象集合
* getElementsByAttribute​(String key):根据属性名称获取元素对象集合
* getElementsByAttributeValue​(String key, String value):根据对应的属性名和属性值获取元素对象集合
			3. Elements:元素Element对象的集合。可以当做 ArrayList<Element>来使用
			4. Element:元素对象
1. 获取子元素对象
* getElementById​(String id):根据id属性值获取唯一的element对象
* getElementsByTag​(String tagName):根据标签名称获取元素对象集合
* getElementsByAttribute​(String key):根据属性名称获取元素对象集合
* getElementsByAttributeValue​(String key, String value):根据对应的属性名和属性值获取元素对象集合 2. 获取属性值
* String attr(String key):根据属性名称获取属性值 3. 获取文本内容
* String text():获取文本内容
* String html():获取标签体的所有内容(包括字标签的字符串内容)
			5. Node:节点对象
* 是Document和Element的父类

快捷查询方式:

1. selector:选择器

使用的方法:Elements select​(String cssQuery)

语法:参考Selector类中定义的语法,selector的语法和css的选择器语法保持一致,使用选择器方式获取xml中的元素,这种方式不通用

2. XPath:XPath即为XML路径语言,它是一种用来确定XML(标准通用标记语言的子集)文档中某部分位置的语言

使用Jsoup的Xpath需要额外导入jar包。

查询w3cshool参考手册,使用xpath的语法完成查询

代码:

/  代表绝对路径
// 代表无论层级下的路径
* 通配符,代表所有
/AAA/BBB[1]中括号中可以指定某个集合中的编号,从1开始
/AAA/BBB[last()]获取集合的最后一个
//BBB[@id]指定带有某个属性的元素
//BBB[@id='b1']选择某个属性等于指定值的元素
返回的是List<JXNode>或者JXNode,JXNode可以直接调用getElement转为原始的Element对##

明明不太合适但是还是被用在配置文件和数据传输上的XML的更多相关文章

  1. Mac下关于——你不能拷贝项目“”,因为它的名称太长或包括的字符在目的宗卷上无效。文件的删除

    内容是google的,测试有效,因为用revel打包的东西删除以后有这个循环bug Mac下关于——你不能拷贝项目“”,因为它的名称太长或包括的字符在目的宗卷上无效.文件的删除 关于这个问题我找到的一 ...

  2. API设计原则(觉得太合适,转发做记录)

    API设计原则 对于云计算系统,系统API实际上处于系统设计的统领地位,正如本文前面所说,K8s集群系统每支持一项新功能,引入一项新技术,一定会新引入对应的API对象,支持对该功能的管理操作,理解掌握 ...

  3. ORACLE 监听日志文件太大停止写监听日志引起数据库连接不上问题

    生产库监听日志文件太大(达到4G多),发现oracle停止写监听日志,检查参数log_file,log_directory,log_status 均正常,数据库运行也正常. 经确认确实为监听日志过大引 ...

  4. Mac下关于->您不能拷贝项目“”,因为它的名称太长或包括的字符在目的宗卷上无效。<-的删除

    打开 Terminal 应用程序. 键入: sudo rm -rf注意:在"-rf"后键入一个空格.没有空格该命令将不能执行.在步骤 6 之前请不要按下 Return 键. 打开您 ...

  5. netbeans 优化设置

    下面我就以Windows上的NetBeans安装为例,说说如何配置字体. 1.NetBeans界面上的普通字体大小,可以通过配置NetBeans安装目录下netbeans.conf启动文件来实现,这个 ...

  6. EasyUI_Datagrid学习总结

    EasyUI_Datagrid学习总结 2016年7月25日星期一 一.简介 Easyui中的datagrid从总的作用上讲,就是在列表上显示数据,类似于table,但是在table的基础上,此控件更 ...

  7. iOS - Target-Action机制创建自己的UI控件需要了解的知识

    我们在开发应用的时候,经常会用到各种各样的控件,诸如按钮(UIButton).滑块(UISlider).分页控件(UIPageControl)等.这些控件用来与用户进行交互,响应用户的操作.我们查看这 ...

  8. 01 Netty是什么?

    01 Netty是什么? IO编程 我们简化下场景:客户端每隔两秒发送一个带有时间戳的 "hello world" 给服务端,服务端收到之后打印. 为了方便演示,下面例子中,服务端 ...

  9. Spring AOP 源码分析 - 筛选合适的通知器

    1.简介 从本篇文章开始,我将会对 Spring AOP 部分的源码进行分析.本文是 Spring AOP 源码分析系列文章的第二篇,本文主要分析 Spring AOP 是如何为目标 bean 筛选出 ...

随机推荐

  1. 前端工具【0】—— Emmet插件

    介绍:Emmet是许多流行文本编辑器的插件,它极大地改进了HTML和CSS工作流程 .为大部分流行的编辑器都提供了安装插件,核心是缩写语法+tab键(不同编辑器可自行设置),以下是我整理的常用知识点. ...

  2. pycharm默认的模板修改python script

    #!/usr/bin/env python # encoding: utf-8 #set( $SITE = "https://www.cnblogs.com/c-x-a" ) &q ...

  3. JS-关闭当前窗口

    不提示直接关闭 默认有提示,若希望不提示直接关闭则需要使用(并非兼容全部浏览器) window.opener=null; window.open('','_self'); window.close() ...

  4. mysql_DCL_grant/revoke

    授权就是为某个用户赋予某些权限.例如,可以为新建的用户赋予查询所有数据库和表的权限.合理的授权能够保证数据库的安全.不合理的授权会使数据库存在安全隐患. MySQL中使用GRANT关键字来为用户设置权 ...

  5. SEC8 - MySQL 查询语句--------------进阶4:常见的函数

    # 进阶4:常见的函数 /* 概念:将一组逻辑语句封装在方法体中,对外暴露方法名 好处:1.隐藏了实现细节 2.提高代码的复用性 调用: select 函数名() [from 表]; 特点: (1)叫 ...

  6. String.prototype.includes

    if (!String.prototype.includes) {   String.prototype.includes = function(search, start) {     'use s ...

  7. JavaWeb——servlet1

    一.servlet简介 Servlet(Server Applet)是Java Servlet的简称,称为小服务程序或服务连接器,用Java编写的服务器端程序,具有独立于平台和协议的特性,主要功能在于 ...

  8. java8新特性-简介

    一.主要内容 :其中最为核心的为lambda 表达式 与 Stream API lambda表达式 函数式接口 方法引用与构造器引用 Stream API 接口中的默认方法与静态方法 新时间日期API ...

  9. [BZOJ3622] 已经没有什么好害怕的了(dp+容斥)

    Description: ​ 有两个数组a和b,两两配对,求 \(a_i>b_i\) 的配对比 \(b_i>a_i\) 的配对多 \(k\) 个的方案数 \(k\le n\le 2000\ ...

  10. 并行开发 2.plink

    原文:8天玩转并行开发——第二天 Task的使用 在我们了解Task之前,如果我们要使用多核的功能可能就会自己来开线程,然而这种线程模型在.net 4.0之后被一种称为基于 “任务的编程模型”所冲击, ...