zoukankan      html  css  js  c++  java
  • XPath 实例

    在本节,让我们通过实例来学习一些基础的 XPath 语法。

    XML实例文档

    我们将在下面的例子中使用这个 XML 文档:

    "books.xml" :

    <?xml version="1.0" encoding="ISO-8859-1"?>
    
    <bookstore>
    
    <book category="COOKING">
      <title lang="en">Everyday Italian</title>
      <author>Giada De Laurentiis</author>
      <year>2005</year>
      <price>30.00</price>
    </book>
    
    <book category="CHILDREN">
      <title lang="en">Harry Potter</title>
      <author>J K. Rowling</author>
      <year>2005</year>
      <price>29.99</price>
    </book>
    
    <book category="WEB">
      <title lang="en">XQuery Kick Start</title>
      <author>James McGovern</author>
      <author>Per Bothner</author>
      <author>Kurt Cagle</author>
      <author>James Linn</author>
      <author>Vaidyanathan Nagarajan</author>
      <year>2003</year>
      <price>49.99</price>
    </book>
    
    <book category="WEB">
      <title lang="en">Learning XML</title>
      <author>Erik T. Ray</author>
      <year>2003</year>
      <price>39.95</price>
    </book>
    
    </bookstore>

    加载 XML 文档

    所有现代浏览器都支持使用 XMLHttpRequest 来加载 XML 文档的方法。

    针对大多数现代浏览器的代码:

    var xmlhttp=new XMLHttpRequest()

    针对古老的微软浏览器(IE 5 和 6)的代码:

    var xmlhttp=new ActiveXObject("Microsoft.XMLHTTP")

    选取节点

    不幸的是,Internet Explorer 和其他处理 XPath 的方式不同。

    在我们的例子中,包含适用于大多数主流浏览器的代码。

    Internet Explorer 使用 selectNodes() 方法从 XML 文档中的选取节点:

    xmlDoc.selectNodes(xpath);

    Firefox、Chrome、Opera 以及 Safari 使用 evaluate() 方法从 XML 文档中选取节点:

    xmlDoc.evaluate(xpath, xmlDoc, null, XPathResult.ANY_TYPE,null);

    选取所有 title

    下面的例子选取所有 title 节点:

    /bookstore/book/title

    选取第一个 book 的 title

    下面的例子选取 bookstore 元素下面的第一个 book 节点的 title:

    /bookstore/book[1]/title

    这里有一个问题。上面的例子在 IE 和其他浏览器中输出不同的结果。

    IE5 以及更高版本将 [0] 视为第一个节点,而根据 W3C 的标准,应该是 [1]。

    为了解决 IE5+ 中 [0] 和 [1] 的问题,可以为 XPath 设置语言选择(SelectionLanguage)。

    下面的例子选取 bookstore 元素下面的第一个 book 节点的 title:

    xml.setProperty("SelectionLanguage","XPath");
    xml.selectNodes("/bookstore/book[1]/title");

    选取所有价格

    下面的例子选取 price 节点中的所有文本:

    /bookstore/book/price/text()

    选取价格高于 35 的 price 节点

    下面的例子选取价格高于 35 的所有 price 节点:

    /bookstore/book[price>35]/price

    选取价格高于 35 的 title 节点

    下面的例子选取价格高于 35 的所有 title 节点:

    /bookstore/book[price>35]/title
  • 相关阅读:
    理解全虚拟、半虚拟以及硬件辅助的虚拟化
    使用PowerShell向SharePoint中写入数据
    Python的时间模块小结(转自:不懂真人)
    Windows下如何安装Python的第三方库
    Python的正则表达式笔记
    PG, Pool之间的一些数量关系
    Ceph与OpenStack的Nova相结合
    rbd命令
    rados命令
    ceph命令
  • 原文地址:https://www.cnblogs.com/xxsl/p/6231632.html
Copyright © 2011-2022 走看看