gpt4 book ai didi

html - 如何通过有条件地排除父节点的前一个兄弟节点来选择子节点

转载 作者:行者123 更新时间:2023-11-28 20:31:18 31 4
gpt4 key购买 nike

我有一个关于在 Selenium IDE 中使用(对我来说是什么)一些复杂的 XPath 查询的问题(认为它们通常适用于 XPath)。

首先,这是我的场景。

我正在为我正在处理的网站的一项功能编写一些自动化测试,该网站上只有某些待售商品具有。我正在尝试以数据更改不会破坏测试的方式设计测试。这是我正在测试的内容的抽象:

给定一组搜索结果,结果中的某些产品将具有一个特征(我们称之为特征属性),我想点击第一个具有单一价格和属性的结果(将来可能会改变) .

我正在使用 Selenium IDE 2.5.0/FF 28。

这是我创建的 JsFiddle,它模拟我必须使用的标记/DOM 结构(无法更改标记):http://jsfiddle.net/xDaevax/3qUHB/6/

这是我的 XPath 查询:

//div[contains(@class, 'primary')]//div[contains(@class, 'results')]//div[@class='price-range']/span[not(contains(@class, 'seperate'))]/../../..//a[@class='detail-link']

本质上,问题是这样的:所有三个都具有相同的包装标记和 css 类信息,但由于第二个元素(我要找的那个)没有,它们在价格范围类上有所不同“单独的”或“最少的”CSS 类元素。

我已经使用 XPath 选择器做到了这一点,但还是卡住了。我假设当我使用“/../..”遍历返回 DOM 时,我丢失了我之前使用的条件 XPath 子句。

对于细节的含糊不清,我深表歉意,但由于契约(Contract)限制,我尽可能做到笼统。任何关于如何实现我想要的选择的建议将不胜感激。如果我需要澄清我尝试过的任何要求或步骤,请告诉我。

编辑:以下是对预期结果的简要描述。

在给定的标记示例中,我只想选择并单击中间结果元素中的链接。这是因为中间元素具有所需的“属性”,一旦单击链接,它会将您带到产品页面,其中包含需要测试的其他内容。也就是说,数据可能会发生变化:今天它是列表中的第二个元素,但明天它可能是 16 个总元素中的第 7 个元素。

我当前的 XPath 逻辑(尽管我的解决方案不起作用)如下:我感兴趣的元素与其他结果有区别,原因有两点:1),它有一个详细信息超链接(稍后将被点击)和 2)它没有价格范围(与第一个结果不同)。因为第一个结果也有一个超链接,所以两者之间的唯一区别是第一个结果有一个最小和分隔符标记元素,而第二个没有(我的目标链接总是有一个单一的价格而不是一个范围)。基于此信息,我尝试编写 XPath,它将选择不包含在具有价格范围的元素中的第一个超链接。

最佳答案

此表达式将选择所有三个 div元素:

//div[contains(@class, 'primary')]
//div[contains(@class, 'results')]
//div[@class='price-range']

如果我正确理解了您的要求,price-range div必须有一个 sibling 是 <a href>元素,所以我们可以过滤掉最后一个 div通过在谓词中添加该限制:[../a[@href]] .所以这个表达式只选择前两个 div小号:

//div[contains(@class, 'primary')]
//div[contains(@class, 'results')]
//div[@class='price-range']
[../a[@href]]

现在您可以再添加一个谓词来删除没有单一价格的商品。您选择了 separate类作为标准,因此我们可以更改最后一个谓词并为其添加另一个限制:[../a[@href] and not(span[contains(@class,'separate')])] .现在您的表达式选择了 div你想要的:

//div[contains(@class, 'primary')]
//div[contains(@class, 'results')]
//div[@class='price-range']
[../a[@href] and not(span[contains(@class,'separate')])]

这是一个位置路径,它创建了一个上下文。从这个上下文中,您可以导航到任何您想要的地方。你可以得到兄弟<a href>添加一个新步骤及其相对路径:../a .因此,最后,此表达式选择与您的 div 处于同一级别的链接。 :

//div[contains(@class, 'primary')]
//div[contains(@class, 'results')]
//div[@class='price-range']
[../a[@href] and not(span[contains(@class,'separate')])]
/../a

或者在一行中:

//div[contains(@class, 'primary')]//div[contains(@class, 'results')]//div[@class='price-range'][../a[@href] and not(span[contains(@class,'separate')])]/../a

关于html - 如何通过有条件地排除父节点的前一个兄弟节点来选择子节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23767962/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com