xml中的空格之完全解说

提示:我提取了《xslt从入门到精通》中关于空格解释的核心部分,借以抛砖引玉,希望大家踊跃参与讨论。谈谈你对空格的理解。

只适合对xml文件结构有一定了解的学者,不适合初学者。请按从上至下的顺序阅读。

对html文件而言,空格不重要;然而,对xml而言,默认立场就是要保留空格结点(空格结点的解释见下文)。

根据xml规范的规定,所谓空格是四种字符的任意组合序列:
-----------------------
空格字符(space),对应字符值为 #x20
返回字符(Carriage Return),对应字符值为 #xD
新行字符(Newline),对应字符值为 #xA
跳格字符(Tab),对应字符值为 #x9。

xml文件的空格也会形成结点,也就是空格结点。空格结点属于文字结点类型。

对xml和xslt而言,空格结点会牵涉到两个议题:
-----------------------
1。在xml输入文件中决定哪些空格是重要的,xslt处理器要看见这些空格结点。而决定的密钥就是xml:space属性。
2。在xsl模板文件中决定哪些空格是重要的,xslt处理器应将它复制到结果树中,而决定的密钥就是xsl:strip-space
和xsl:preserve-space这两个命令。

“重要和不重要的空格结点”
-----------------------
若某组件的内容只能放组件,则该组件中的空格结点就是不重要的(Insignificant);
如果某组件的内容是#PCDATA的类型,则其内的空格结点应视为重要的(Signficant)。
至于组件内容混杂了文字内容和组件的情况则无从评判,应视组件及其内容之语意而定。

xslt处理器接触到xml输入文件之前,会先由xml分析器进行分析
-----------------------
(1)xml:space属性可以改变后续接手的xml应用程序处理空格结点的模式,例如,xslt处理器就会受xml:space属性影响。
(2)xml文件中任何一列标记或内容尾端的结尾的结尾符号全部会换成单一新行字符(#xA)。
(3)属性值交给xml应用程序之前,xml分析器也应该先对属性值做规范化的操作。这是因为不同的操作系统每一行文字列的结尾字符有不同的组合,例如,windows系统会由返回字符呵新行字符组成结尾符号,而Unix系统则仅由新行字符组
     成结尾符号。xml分析器在读取xml文件之后,便先行将所有结尾符号换成单一新行字符,不仅统一了不同系统间不同结尾符号设计的差异性,同时也简化了后续xml应用程序的的操作难度。这样一个处理过程称为“规范化(Normalization)”。
 a,每一文字列的结尾符号都要规范化成单一的新行字符(#xA)。
 b,任何一个空格符(#x20、#xD、#xA、#x9)都应换成一个空格字符(#x20)。
 c,属性值中若含有字参码,则应替换成该参考字符,例如, 会换成新行字符(#xA)。
 d,属性值若含有实体参考,则应以其替换文字替换。
 e,除此之外,任何字符都应直接放入规范化属性值中。
 f,最后,如果属性类型不是CDATA,则xml分析器应该再进一步把属性值前后的空格字符序列删除,而且属性值中间若有空格序列,也应该替换成单一空格字符。

xslt处理器把xml输入文件和xsl模板文件的结构树建好之后,会现把组件中相邻的文字结点合并成单一的文字结点,然后再把一些文字结点抽掉。然而,如果文字结点符合下列条件之一,就会被保留下来:
-----------------------
(1)文字结点的父组件是空格保留组件名称集(Set Of Whitespace-preserving Element Names)中的一员。
(2)文字结点中至少有一个非空格符。
(3)文字结点的某个祖先组件中有xml:space属性,其值为preserve,而且较近的祖先组件中没有其他xml:space属性值为default。除此之外的文字结点逗会被抽掉。

对xsl模板而言,所谓的空格保留组件名称集只有一个xsl:text组件可用。xsl模板文件的空格结点都会被删除,但是,如果空格结点出现在xsl:text组件中就会被保留下来。

(0)

相关推荐

  • xml中的空格之完全解说

    提示:我提取了<xslt从入门到精通>中关于空格解释的核心部分,借以抛砖引玉,希望大家踊跃参与讨论.谈谈你对空格的理解. 只适合对xml文件结构有一定了解的学者,不适合初学者.请按从上至下的顺序阅读. 对html文件而言,空格不重要:然而,对xml而言,默认立场就是要保留空格结点(空格结点的解释见下文). 根据xml规范的规定,所谓空格是四种字符的任意组合序列: ----------------------- 空格字符(space),对应字符值为 #x20 返回字符(Carriage Retu

  • python 截取XML中bndbox的坐标中的图像,另存为jpg的实例

    文件目录 Annotations中是XML文件. JPEGImages中是对应的JPG文件 XML文件 要截取bndbox坐标中的内容. python代码 # -*- coding: utf-8 -*- # @Time : 2020/2/8 22:14 # @Author : SanZhi # @File : get_xml.py # @Software: PyCharm import cv2 import numpy as np import xml.dom.minidom import os

  • XML中显示HTML的小技巧

    今天用XSLT转换XML,发现XML中的HTML代码显示不正常.比如: XML文件: <root> <date><![CDATA[<img border=0 src='images/w3china_logo.gif'>]]</date> </root> XSLT文件: <xsl:value-of select="root/date" > 发现这样输入显示的是<img border=0 src='imag

  • 往xml中更新节点的实例代码

    往xml中更新节点的实例代码 /* System.out.println("2323"); DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder docbuilder = factory.newDocumentBuilder(); Document parse = docbuilder .parse(new File("src/ProdQuery.xml&q

  • jsp实现将信息放入xml中的方法

    本文实例讲述了jsp实现将信息放入xml中的方法.分享给大家供大家参考,具体如下: 一.jsp代码: 省: <select id="province" name="province" onchange="jsSubmit()"> <option value="北京" selected="selected">北京</option> <option value=&quo

  • JSP取得在WEB.XML中定义的参数

    在WEB.XML文件中设置参数: <?xml version="1.0" encoding="ISO-8859-1"?> <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd"> <web-app> &

  • 解决vue.js在编写过程中出现空格不规范报错的问题

    找到build文件夹下面的webpack.base.conf.js文件. 然后打开该文件,找到图下这段代码,把他注释掉. 注释掉之后,再进行子页面等编写的时候,空格不规范的情况下也不会再报错啦.因为这个报错对于初学者来说实在头大.哈哈O(∩_∩)O哈哈~ 我标注的这些地方,原本是有严格的空格规范要求的,这些报错真是另人烦躁呀o(╥﹏╥)o 反正我把这个问题解决了,特别开心哒哒哒~~~ 以上这篇解决vue.js在编写过程中出现空格不规范报错的问题就是小编分享给大家的全部内容了,希望能给大家一个参考

  • Java中去除字符串中所有空格的几种方法

    JAVA中去掉空格 1. String.trim() trim()是去掉首尾空格 2.str.replace(" ", ""); 去掉所有空格,包括首尾.中间  复制代码 代码如下: String str = " hell o ";  String str2 = str.replaceAll(" ", "");  System.out.println(str2); 3.或者replaceAll("

  • php中替换字符串中的空格为逗号','的方法

    今天在网查到一篇介绍php中替换字符串中的空格为逗号','的文章,作个日记保存下来. 复制代码 代码如下: <pre name="code" class="php"><? php /* * 关键词中的空格替换为',' */ public function emptyreplace($str) { $str = str_replace(' ', ' ', $str); //替换全角空格为半角 $str = str_replace(' ', ' ',

  • Python解析xml中dom元素的方法

    本文实例讲述了Python解析xml中dom元素的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: from xml.dom import minidom try:     xmlfile = open("path.xml", "a+")     #xmldoc = minidom.parse( sys.argv[1])     xmldoc = minidom.parse(xmlfile) except :     #updatelogger.

随机推荐