02.29 关键词搜索后的链接XPath怎么写?

赵连常


这里给你提供一些资料吧,我从网络上给你找的,希望对你有用,

我也刚刚学不久,希望这些信息对你有帮助


XPath 是一门在 XML 文档中查找信息的语言。XPath 用于在 XML 文档中通过元素和属性进行导航。

XPath 含有超过 100 个内建的函数。这些函数用于字符串值、数值、日期和时间比较、节点和 QName 处理、序列处理、逻辑值等等。

XPath 是 W3C 标准,XPath 于 1999 年 11 月 16 日 成为 W3C 标准。XPath 被设计为供 XSLT、XPointer 以及其他 XML 解析软件使用。

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

XML 文档是被作为节点树来对待的。树的根被称为文档节点或者根节点。

一、选取节点

常用的路径表达式:


二、谓词:被嵌在方括号内,用来查找某个特定的节点或包含某个制定的值的节点


三、通配符:Xpath通过通配符来选取未知的XML元素


四、取多个路径:使用“ | 运算符可以选取多个路径


五、Xpath轴:轴可以定义相对于当前节点的节点集


六、功能函数:使用功能函数能够更好的进行模糊搜索


七、常用函数:

1、精确定位

(1)contains(str1,str2)用来判断str1是否包含str2例1://*[contains(@class,'c-summaryc-row ')]选择@class值中包含c-summary c-row的节点例2://div[contains(.//text(),'价格')]选择text()中包含价格的div节点

(2)position()选择当前的第几个节点例1://*[@class='result'][position()=1]选择@class='result'的第一个节点例2://*[@class='result'][position()<=2]选择@class='result'的前两个节点

(3)last()选择当前的倒数第几个节点例1://*[@class='result'][last()]选择@class='result'的最后一个节点例2://*[@class='result'][last()-1]选择@class='result'的倒数第二个节点

(4)following-sibling 选取当前节点之后的所有同级节点例1://div[@class='result']/following-sibling::div选择@class='result'的div节点后所有同级div节点找到多个节点时可通过position确定第几个如://div[@class='result']/following-sibling::div[position()=1]

(5)preceding-sibling 选取当前节点之前的所有同级节点使用方法同following-sibling


2、过滤信息

(1)substring-before(str1,str2)用于返回字符串str1中位于第一个str2之前的部分例子:substring-before(.//*[@class='c-more_link']/text(),'条')返回.//*[@class='c-more_link']/text()中第一个'条'前面的部分,如果不存在'条',则返回空值

(2)substring-after(str1,str2)跟substring-before类似,返回字符串str1中位于第一个str2之后的部分例1:substring-after(.//*[@class='c-more_link']/text(),'条')返回.//*[@class='c-more_link']/text()中第一个’条’后面的部分,如果不存在'条',则返回空值例2:substring-after(substring-before(.//*[@class='c-more_link']/text(),'新闻'),'条')返回.//*[@class='c-more_link']/text()中第一个'新闻'前面与第一个'条'后面之间的部分

(3)normalize-space()用来将一个字符串的头部和尾部的空白字符删除,如果字符串中间含有多个连续的空白字符,将用一个空格来代替例子:normalize-space(.//*[contains(@class,'c-summaryc-row ')])

(4)translate(string,str1,str2)假如string中的字符在str1中有出现,那么替换为str1对应str2的同一位置的字符,假如str2这个位置取不到字符则删除string的该字符例子:translate('12:30','03','54')结果:'12:45'

3、拼接信息

(1)concat()函数用于串连多个字符串例子:concat('http://baidu.com',.//*[@class='c-more_link']/@href)


分享到:


相關文章: