草庐IT

XPath 轴(Axes)

全部标签

ruby - capybara - 使用 xPath 查找正在离开范围内

我正在尝试使用默认的Rails日期、时间和日期时间字段通过Capybara构建一个日期选择器。我正在使用within方法来查找该字段的选择框,但是当我使用xPath查找正确的框时,它会离开within范围并在元素的页面。这是我使用的代码。我正在测试的页面有2个日期时间字段,但由于这个错误,我只能让它更改第一个。目前我有一个div容器,其id包含日期时间字段,但我确实计划切换代码以通过标签查找。moduleMarketronmoduleDateTimedefselect_date(field,options={})date_parse=Date.parse(options[:with])

ruby yaml ypath 像 xpath?

你好,我有一个像这样的yaml文件---data:-date:"2004-06-11"description:Firstdescription-date:"2008-01-12"description:Anotherdescripion我如何为xml执行类似于xpath的“ypath”查询?类似于“获取日期为2004-06-11的描述”YAML.parse_file('myfile.yml').select('/data/*/date==2004-06-11')你是怎么做到的,如果可能的话,我怎样才能类似地通过“ypath”编辑描述?谢谢 最佳答案

ruby - 用于类似正则表达式匹配的 xpath 表达式?

我想在具有特定模式的html文档中搜索divid。我想在正则表达式中匹配这个模式:foo_([[:digit:]]{1.8})使用xpath。上述模式的xpath等价物是什么?我坚持//div[@id="foo_然后什么?如果有人能为它继续一个合法的表达。编辑抱歉,我想我必须详细说明一下。其实不是foo_,它是post_message_顺便说一句,我使用mechanize/nokogiri(ruby​​)这是片段:html_doc=Nokogiri::HTML(open(myfile))message_div=html_doc.xpath('//div[substring(@id,13

ruby - 如何在 XPath 中获取序列的最后一个元素?

在Ruby中,我们可以访问带有负数的数组,如array[-1]以获取数组中的最后一个对象。我如何使用XPath执行此操作?我不能这样做:result=node.xpath('.//ROOT/TAG[-1]/KEY_NAME')我在StackOverflow上找到了一个解决方案,但那是一个仅更改上限以获取元素的查询。这可能会返回最后一项或最后一项和上一项。如果我想在Ruby中只获取前一个元素,如array[-2]怎么办? 最佳答案 您可以在谓词中使用last()访问XPath中的最后一个元素。node.xpath('.//ROOT/T

ruby - XPath 轴,获取所有后续节点直到

我有以下HTML示例:FoobarloremipsumetcBarbazdumdumdumpoopfiddles我希望提取“Foobar”标题后的所有段落,直到到达“Barbaz”标题(“Barbaz”标题的文本未知,所以很遗憾我无法使用答案由bougyman提供)。现在我当然可以使用//h2[text()='Foobar']/following::p之类的东西,但这当然会抓取此后的所有段落header。因此,我可以选择遍历节点集并将段落插入数组,直到文本与下一个header的文本相匹配,但老实说,这远不如在XPath中完成这件事那么酷。有没有办法做到这一点我想念的?

ruby - 如何创建 nokogiri 不区分大小写的 Xpath 选择器?

我正在使用nokogiri来选择“关键字”属性,如下所示:putspage.parser.xpath("//meta[@name='keywords']").to_html我正在使用的其中一个页面的关键字标签带有大写字母“K”,这促使我使查询不区分大小写。AND所以,我的问题是:使nokogiri选择不区分大小写的最佳方法是什么?编辑下面Tomalak的建议非常适合这个特定问题。我还想使用这个例子来帮助更好地理解nokogiri,并且有几个我想知道但没有成功搜索的问题。例如,正则表达式“伪类”是NokogiriDocs吗?适合这样的问题吗?我也很好奇nokogiri中的matches?

硒c#,xpath没有识别

我有元素,但是XPATH无法正常工作,无法找到XPATH的元素。varnewnumber=driver.findelement(by.xpath(“//div[@ID='149694333073-0-0-uigrid-0006-cell']/div”));请在这件事上给予我帮助?看答案要处理动态ID,他们最简单的事情就是将其删除。如何在Chrome中这样做:右键单击元素,然后选择“检查”双击元素的ID=“...”以编辑它删除属性并保存更改(通过单击另一个元素)右键单击元素,然后选择“复制”->“复制XPath”

ruby - 如何在 Nokogiri 中使用带有 XPath 的 xmlns 声明

我正在使用Nokogiri::XML来解析来自AmazonSimpleDB的响应。响应类似于:Foo42BarXYZ如果我直接将响应交给Nokogiri,所有XPath查询(例如doc/"//Item/Attribute[Name='Foo']/Value")都会返回一个空数组。但是,如果我从SelectResponse标记中删除xmlns属性,它就可以正常工作。我需要做一些额外的事情来解释命名空间声明吗?这种解决方法感觉非常像黑客攻击。 最佳答案 该XPath查询查找不在任何命名空间中的元素。您需要告诉您的XPath处理器您正在寻

ruby - 我如何在 Nokogiri 中使用 XPath?

我还没有找到任何文档或教程。有没有这样的东西?doc.xpath('//table/tbody[@id="threadbits_forum_251"]/tr')上面的代码将在任何地方为我提供任何表,它有一个tbody子级,其属性id等于“threadbits_forum_251”。但是为什么要以双//开头呢?为什么最后会有/tr?有关详细信息,请参阅“RubyNokogiriParsingHTMLtableII”。谁能告诉我如何提取href、id、alt、src等,使用野切?td[3]/div[1]/a/text()'如何提取其他东西? 最佳答案

Javascript Xpath 和默认命名空间

我有一些JavaScript/Xpath无法正常工作。(availableonjsfiddle)看起来我在XML命名空间上做错了什么,阻止我通过节点(标记)名称查询我的元素。如果我尝试查询当前节点的所有子节点,我会毫无问题地找到元素myElement:varxpathResult=xmlDoc.evaluate("child::*",rootElement,nsResolver,XPathResult.ORDERED_NODE_ITERATOR_TYPE,null);varqueryEl;if(queryEl=xpathResult.iterateNext()){alert("chil