当属性包含多个单词时,我有一个按属性选择节点的问题。例如:
<div class="atag btag" />
这是我的xpath表达式:
/ / * [@class =’atag’]
这个表达式适用于
<div class=“atag” />
但对于前面的例子不是这样。我如何选择<div>?
当属性包含多个单词时,我有一个按属性选择节点的问题。例如:
<div class="atag btag" />
这是我的xpath表达式:
/ / * [@class =’atag’]
这个表达式适用于
<div class=“atag” />
但对于前面的例子不是这样。我如何选择<div>?
当前回答
下面是一个找到className包含atag的div元素的例子:
//div[contains(@class, 'atag')]
下面是一个找到className包含atag和btag的div元素的例子:
//div[contains(@class, 'atag') and contains(@class ,'btag')]
然而,它也会找到部分匹配,如class="catag bobtag"。
如果你不想要部分匹配,请看下面bobince的答案。
其他回答
Mjv的答案是一个很好的开始,但如果atag不是列出的第一个类名,则会失败。
通常的方法相当笨拙:
//*[contains(concat(' ', @class, ' '), ' atag ')]
只要类之间仅用空格分隔,而不是其他形式的空格,这种方法就有效。情况几乎总是如此。如果它可能不是,你必须让它变得更笨拙:
//*[contains(concat(' ', normalize-space(@class), ' '), ' atag ')]
(通过类名一样的空格分隔字符串进行选择是非常常见的情况,令人惊讶的是它没有特定的XPath函数,比如CSS3的'[class~="atag"]'。)
下面是一个找到className包含atag的div元素的例子:
//div[contains(@class, 'atag')]
下面是一个找到className包含atag和btag的div元素的例子:
//div[contains(@class, 'atag') and contains(@class ,'btag')]
然而,它也会找到部分匹配,如class="catag bobtag"。
如果你不想要部分匹配,请看下面bobince的答案。
工作的2.0 XPath:
//*[tokenize(@class,'\s+')='atag']
或者用一个变量:
//*[tokenize(@class,'\s+')=$classname]
请注意,如果您可以假设您感兴趣的类名不是另一个可能的类名的子字符串,bobince的答案可能会过于复杂。如果这是真的,您可以通过contains函数简单地使用子字符串匹配。下面将匹配任何类包含子字符串'atag'的元素:
//*[contains(@class,'atag')]
如果上面的假设不成立,子字符串匹配将匹配您不打算匹配的元素。在这种情况下,你必须找到单词边界。通过使用空格分隔符找到类名边界,bobince的第二个答案找到了精确的匹配:
//*[contains(concat(' ', normalize-space(@class), ' '), ' atag ')]
这将匹配atag而不是matag。
你可以试试下面的方法
By.CssSelector(“div.atag.btag”)