Selenium学习---(三)

关于XPath的学习
1.XPath 是XML 的查询语言,和SQL 的角色很类似。以下面XML 为例,介绍XPath 的语法。

<?xml version="1.0" encoding="ISO-8859-1"?>
<catalog>
    <cd country="USA">
        <title>Empire Burlesque</title>
        <artist>Bob Dylan</artist>
        <price>10.90</price>
    </cd>
    <cd country="UK">
        <title>Hide your heart</title>
        <artist>Bonnie Tyler</artist>
        <price>9.90</price>
    </cd>
    <cd country="USA">
        <title>Greatest Hits</title>
        <artist>Dolly Parton</artist>
        <price>9.90</price>
    </cd>
</catalog>

如果XPath开头是一个(/)——表明是绝对路径
如果XPath开头是一个人(//)—–表明文件中所有符合模式的元素都会被选出来,不管处于什么层级

first:例如要选catalog 底下的cd 中所有price 元素—–/catalog/cd/price
second:以下的语法会选出文件中所有叫做cd 的元素(在树中的任何
层级都会被选出来):—–//cd
third:选择未知的元素。下面这个语法会选出/catalog/cd 的所有子元素:—/catalog/cd/
fourth:以下的语法会选出所有catalog 的子元素中,包含有price 作为子元素的元素。—/catalog/*/price
fifth:以下的语法会选出有两层父节点,叫做price 的所有元素–/*/*/price
sixth:以下的语法会选择出文件中的所有元素。—-//*

注意:想要存取不分层级的元素,XPath语法必须(//)开头;存取位置元素用(*),星号只能代表未知名称的元素,不能代表未知层级的元素

2.选择分支
注意:XPath没有第0元素这种说法。

/catalog/cd[1] ---- 从catalog 的子元素中取出第一个叫做cd 的元素,XPath并没有定义first() 这种函式喔
/catalog/cd[last()]  ----选择catalog 中的最后一个cd 元素
/catalog/cd[price]   ----选出含有price 子元素的所有/catalog/cd 元素。
/catalog/cd[price=10.90] ---选出price 元素的值等于10.90的所有/catalog/cd 元素
/catalog/cd[price=10.90]/price   ----选出price 元素的值等于10.90的所有/catalog/cd 元素的price 元素

3.选择一个以上的路径
选择所有title 以及artist 元素/catalog/cd/title | catalog/cd/artist
选择所有title 以及artist 元素//title | //artist
选择所有title 以及artist 以及price 元素//title | //artist | //price

4.选择属性
属性都是以@开头
选择文件中所有叫做country 的属性。—-//@country
选择所有含有country 这个属性的cd 元素:—//cd[@country]
选择出含有属性的所有cd 元素—//cd[@*]
选择出country 属性值为UK 的cd 元素—//cd[@country='UK']

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值