xml文件中的XPATH、DTD

更新日期: 2019-08-05阅读: 2k标签: xml

一、先来说说XPATH

1、XPATH 概念

XPath 是一门在 XML 文档中查找信息的语言,可用来在 XML 文档中对元素和属性进行遍历。XPath 是 W3C XSLT 标准的主要元素,并且 XQuery 和 XPointer 同时被构建于 XPath 表达之上。因此,对 XPath 的理解是很多高级 XML 应用的基础。XPath 非常类似对数据库操作的 SQL 语言,或者说 jquery,它可以方便开发者抓起文档中需要的东西。(dom4j 也支持 xpath)

2.节点类型

XPath 中有七种结点类型:元素、属性、文本、命名空间、处理指令、注释以及文档节点 (或称为根节点)。

文档中存在元素节点,属性节点,根节点

3.常用路径表达式

表达式 描述

节点名称(nodename) 选取此节点的所有子节点

/ 从根节点选取

// 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置

. 选取当前节点

.. 选取当前节点的父节点

@ 选取属性

示例如下:

//@lang 选取所有名为 lang 的属性

4.限定语

用来查找某个特定的节点或者包含某个指定的值的节点。以方括号括起

//book[price>35.00] 选择所有 book 元素,且其中的 price 元素的值须大于 35.00 
/bookstore/book[1] 选取属于 bookstore 子元素的第一个 book 元素。 
/bookstore/book[last()] 选取属于 bookstore 子元素的最后一个 book 元素。 
/bookstore/book[last()-1] 选取属于 bookstore 子元素的倒数第二个 book 元素。 
/bookstore/book[position()<3] 选取最前面的两个属于 bookstore 元素的子元素的 book 元素。 
//title[@lang] 选取所有拥有名为 lang 的属性的 title 元素。 
//title[@lang='eng'] 选取所有 title 元素,且这些元素拥有值为 eng 的 lang 属性。 
/bookstore/book[price>35.00] 选取所有 bookstore 元素的 book 元素,且其中的 price 
元素的值须大于 35.00。 
/bookstore/book[price>35.00]/title 选取所有 bookstore 元素中的 book 元素的 title 元 
素,且其中的 price 元素的值须大于 35.00。

5 .通配符

匹配任何元素节点

@* 匹配任何属性节点

node() 匹配任何类型的节点

| 选取若干路径


使用示例

路径表达式 结果

/bookstore/* 选取 bookstore 元素的所有子节点
//* 选取文档中的所有元素 
//title[@*] 选取所有带有属性的 title 元素。 
//book/title | //book/price 选取所有 book 元素的 tilte 和 price 元素。 
//title | //price 选取所有文档中的 title 和 price 元素。 
/bookstore/book/title | //price 选取所有属于 bookstore 元素的 book 元素的 title 元素,以及文档中所有的 price 元素


二、再说DTD

使用 DTD 可以对文档的内容进行约束,XML 中的 DTD 数据必须用<!DOCTYPE>标记说

明,语法格式如下:

<!DOCTYPE 根元素名称[DTD 定义数据]>

XML 的元素内容定义格式如下:

<!ELEMENT 元素内容描述字符串>

DTD 还可以描述子元素的结构,其使用语法:

<!ELEMENT 子元素结构名称 子元素结构表达式>

其中子元素结构有以下几种常用的定义方式:

1.按顺序包括 B、C、D、的所有内容: <!ELEMENT A(B,C,D)>
2.在 A 中要包含 B、C、D、的任意一个的内容: <!ELEMENT A(B|C|D)>
3.在 A 中包含 0-1 个 B: <!ELEMENT A(B?)>
4.在 A 中要包含 1 次以上各 B: <!ELEMENT A(B+)>
5.在 A 中要包含 O 次以上各 B: <!ELEMENT A(B*)>
6.空元素 <!ELEMENT A EMPTY>

如:


<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE persons[ 
<!ELEMENT persons (person+)> 
<!ELEMENT person ( name , password? , age+) > 
<!ATTLIST person sex (男|女) #REQUIRED> 
<!ATTLIST person id ID #REQUIRED> 
<!ELEMENT name (#PCDATA)> 
<!ELEMENT password (#PCDATA)> 
<!ELEMENT age (#PCDATA)> 
>
<persons> 
<person sex="男" id="p1"> 
<name></name> 
<password></password> 
<age></age> 
</person> 
<person sex="女" id="p2"> 
<name></name> 
<password></password> 
<age></age> 
</person> 
</persons> 


链接: https://www.fly63.com/article/detial/5154

JaveScript 中使用 XSLT转换XML文档

我们经常将数据存储在XML 中,在展示的时候需要转换为其它的形式,这里介绍使用XSLT 对XML数据进行转换。要学习XSLT对XML的转换,需要先了解三个文件。

XML入门教程

XML 指可扩展标记语言(EXtensible Markup Language)。XML不会做任何事情,XML被设计用来结构化、存储以及传输信息。我们需要编写软件或者程序,才能传送、接收和显示出这个文档。

PHP中的XML解析的5种方法

不管是桌面软件开发,还是WEB应用,XML无处不在!然而在平时的工作中,仅仅是使用一些已经封装好的类对XML对于处理,包括生成,解析等。假期有空,于是将PHP中的几种XML解析方法总结如下:

XML基础知识总汇

随着json等一些技术的普及,似乎xml的路子越来越窄,虽然xml的一些功能被其他的一些技术代替,但是学习xml还是非常有必要,如果用xml存储一些大量数据,还是有一定优势的,就算你不管这

XML处理指令

处理指令(PIs)允许文档包含用于应用程序的指令。指令并不是文档字符数据的一部分,但是必须通过应用程序传递。 处理指令可以用于将信息传递给应用程序。处理指令可以出现在文档任意位置的标记外部。可以出现在序言中

XML可扩展标记语言

XML:可扩展标记语言,XML的标签是没有被定义过的,需要自行定义,宗旨是做数据传递,而不是做数据展示;1、xml文件最顶端做声明2、所有标记必须成对出现(没有单标记)3、严格区分大小写

JSON和XML之间的区别是什么?

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它完全独立于语言。它基于JavaScript编程语言,易于理解和生成。XML(可扩展标记语言)旨在传输数据,而不是显示数据。这是W3C的推荐。

javascript如何读取xml?

javascript读取xml的方法:使用DOMParser对象解析XML文本并返回一个XML Document对象。然后调用parseFromString()方法读取。

javascript如何读取xml文件?

JavaScript是一种属于网络的脚本语言,通常通过嵌入在HTML中来实现自身的功能。XML文件格式是纯文本格式,在许多方面类似于HTML,XML由XML元素组成。

浅谈XML和JSON的区别

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!