xpath简介_动力节点Java学院整理_XML示例

来源:脚本之家  责任编辑:小易  

function loadXMLDoc(dname){if(window.XMLHttpRequest){xhttp=new XMLHttpRequest();}else{xhttp=new ActiveXObject("Microsoft.XMLHTTP");}xhttp.open("GET",dname,false);xhttp.send("");return xhttp.responseXML;}这段代码是产生一个 ajax 请求,并发送该请求到 dname 这个URL,并采用同步模式发送(等待服务器应答),并将应答返回;主代码:xml=loadXMLDoc("books.xml");加载 books.xmlpath="/bookstore/book[1]/title;解析该xml内容的xpath为/bookstore 节点的 第1本 book 的 标题code for IEif(window.ActiveXObject){xml.setProperty("SelectionLanguagewww.zgxue.com防采集请勿采集本网。

简单说,xpath就是选择XML文件中节点的方法。

sel.xpath()得到的依旧是一个SelectorList 参看原文档 xpath(query) Find nodes matching the xpath query and return the result as a SelectorList instance with all elements flattened.List

所谓节点(node),就是XML文件的最小构成单位,一共分成7种。

String xpath=\"/html/body/form/div/table/a\";List<Node>trNodes=doc.selectNodes(xpath);for(int i=1;i();i+){ Element trElement=(Element)trNodes.get(i);List<Element>tdList=trElement.elements();

- element(元素节点)

/a[contains(@id,'abc')][2] 用这个xpath 就会找不到东西,因为都是独生子女. 你要选中第二个老大,xpath 要这样写 (/span/a)[2] 这个方式在很多地方有效,但在Selenium 中好像无效.

- attribute(属性节点)

不是有选择父元素的轴语法么?AAA/parent: String xpath=\"/html/body/form/div/table/a\";List<Node>trNodes=doc.selectNodes(xpath);for(int i=1;i();i+){ Element trElement=(Element)trNodes.

- text (文本节点)

1、XmlNodeList list=myDoc.SelectNodes(\"/root/list/catalog[@orders>'3'and catalogtype='0']\");2、XmlNodeList list=myDoc.SelectNodes(\"/root/list/catalog[@catalogname='军事新闻']\");3、

- namespace (名称空间节点)

- processing-instruction (处理命令节点)

- comment (注释节点)

- root (根节点)

xpath可以用来选择这7种节点。不过,下面的笔记只涉及最常用的第一种element(元素节点),因此可以将下文中的节点和元素视为同义词。

一、xpath表达式的基本格式

xpath通过"路径表达式"(Path Expression)来选择节点。在形式上,"路径表达式"与传统的文件系统非常类似。

# 斜杠(/)作为路径内部的分割符。

# 同一个节点有绝对路径和相对路径两种写法。

# 绝对路径(absolute path)必须用"/"起首,后面紧跟根节点,比如/step/step/...。

# 相对路径(relative path)则是除了绝对路径以外的其他写法,比如 step/step,也就是不使用"/"起首。

# "."表示当前节点。

# ".."表示当前节点的父节点

二、选择节点的基本规则

- nodename(节点名称):表示选择该节点的所有子节点

- "/":表示选择根节点

- "//":表示选择任意位置的某个节点

- "@": 表示选择某个属性

三、选择节点的实例

先看一个XML实例文档。

<?xml version="1.0" encoding="ISO-8859-1"?><bookstore> <book> <title lang="eng">Harry Potter</title> <price>29.99</price> </book> <book> <title lang="eng">Learning XML</title> <price>39.95</price> </book></bookstore>

[例1]

bookstore :选取 bookstore 元素的所有子节点。

[例2]

/bookstore :选取根节点bookstore,这是绝对路径写法。

[例3]

bookstore/book :选取所有属于 bookstore 的子元素的 book元素,这是相对路径写法。

[例4]

//book :选择所有 book 子元素,而不管它们在文档中的位置。

[例5]

bookstore//book :选择所有属于 bookstore 元素的后代的 book 元素,而不管它们位于 bookstore 之下的什么位置。

[例6]

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

四、xpath的谓语条件(Predicate)

所谓"谓语条件",就是对路径表达式的附加条件。

所有的条件,都写在方括号"[]"中,表示对节点进行进一步的筛选。

[例7]

/bookstore/book[1] :表示选择bookstore的第一个book子元素。

[例8]

/bookstore/book[last()] :表示选择bookstore的最后一个book子元素。

[例9]

/bookstore/book[last()-1] :表示选择bookstore的倒数第二个book子元素。

[例10]

/bookstore/book[position()<3] :表示选择bookstore的前两个book子元素。

[例11]

//title[@lang] :表示选择所有具有lang属性的title节点。

[例12]

//title[@lang='eng'] :表示选择所有lang属性的值等于"eng"的title节点。

[例13]

/bookstore/book[price] :表示选择bookstore的book子元素,且被选中的book元素必须带有price子元素。

[例14]

/bookstore/book[price>35.00] :表示选择bookstore的book子元素,且被选中的book元素的price子元素值必须大于35。

[例15]

/bookstore/book[price>35.00]/title :表示在例14结果集中,选择title子元素。

[例16]

/bookstore/book/price[.>35.00] :表示选择值大于35的"/bookstore/book"的price子元素。

五、通配符

# "*"表示匹配任何元素节点。

# "@*"表示匹配任何属性值。

# node()表示匹配任何类型的节点。

[例17]

//* :选择文档中的所有元素节点。

[例18]

/*/* :表示选择所有第二层的元素节点。

[例19]

/bookstore/* :表示选择bookstore的所有元素子节点。

[例20]

//title[@*] :表示选择所有带有属性的title元素。

六、选择多个路径

用"|"选择多个并列的路径。

[例21]

//book/title | //book/price :表示同时选择book元素的title子元素和price子元素。

很简单,教你一招:这是你的html文件,我命名为test.html然后用xpath匹配:123456import lxml.etreehtml=lxml.etree.parse("test.html")res=html.xpath("/a[@heaf='baidu.com']")info=res[0].xpath('string(.)')print(info)运行结果:内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • java通过xpath解析xml性能比较详解
  • java selenium xpath 定位实现方法
  • java使用xpath解析xml示例分享
  • java使用xpath和dom4j解析xml
  • 深入xpath的详解以及java示例代码分析
  • java编程之xpath介绍
  • xml中显示html的小技巧
  • xpath简介_动力节点java学院整理
  • powerbuilder(pb)中 xml的应用一例
  • 用xslt将xml解析成xhtml的代码
  • 在服务器端的xslt过程中的编码问题
  • 使用xsl将xml文档中的cdata注释输出为html文本
  • xml 增、删、改和查示例
  • 本站用的rss输出
  • asp下利用xml打包网站文件
  • 气象 xml 数据源应用程序开发指南-内容目录
  • xpath取一个节点下的所有文字
  • xpath 详解!
  • XPATH是什么意思
  • xpath获取特定节点下文本值的问题
  • 如何利用xpath获取节点中html文本
  • Xpath 怎么获取元素节点的名字?
  • Selenium中关于XPath中节点后面[1]的诡异问题?
  • xpath 如何获取父节点的名字?
  • XML XPATH
  • java XPath怎么获取节点属性的值
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全xml基础xml示例wml教程首页xml/rssxml示例java通过xpath解析xml性能比较详解java selenium xpath 定位实现方法java使用xpath解析xml示例分享java使用xpath和dom4j解析xml深入xpath的详解以及java示例代码分析java编程之xpath介绍xml中显示html的小技巧xpath简介_动力节点java学院整理powerbuilder(pb)中 xml的应用一例用xslt将xml解析成xhtml的代码在服务器端的xslt过程中的编码问题使用xsl将xml文档中的cdata注释输出为html文本xml 增、删、改和查示例本站用的rss输出asp下利用xml打包网站文件气象 xml 数据源应用程序开发指南-内容目录powerbuilder(pb)中 xml的应用一utf8转成gb2312乱码问题解决方案javascript xml xsl取值及数据修读大数据量的xml文件的读取问题用xslt将xml解析成xhtml的代码jscript与vbscript 操作xml元素属一个用xslt样式将xml解析为xhtml使用spry轻松将xml数据显示到htmxml 增、删、改和查示例asp下利用xml打包网站文件在服务器端的xslt过程中的编码问题powerbuilder(pb)中 xml的应用一例本站用的rss输出读写xml文件的2个小函数javascript xml xsl取值及数据修改编写xml没有代码提示的解决方法使用xsl将xml文档中的cdata注释输出为htmasp下利用xml打包网站文件读大数据量的xml文件的读取问题asp读取xml文件和记数
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved