如何获取包含冒号的特定属性的节点?

时间:2013-09-23 08:51:16

标签: ruby xml nokogiri

我一直在寻找一种方法来查找具有特定属性的元素节点,并找到: “Use Nokogiri to get all nodes in an element that contain a specific attribute name

但是,当属性有冒号时它不起作用,例如“foo:bar”,如

<abc foo:bar="hello"></abc>

(是的,有效)。

然而,当我使用:

elements = @doc.xpath("//*[@foo:bar]")

我明白了:

unexpected ':' after '#<Nokogiri::CSS::Node:0x107458870>' (Nokogiri::CSS::SyntaxError)

而且,当我使用时:

elements = @doc.xpath("//*[@foo\\:bar]")

我明白了:

Invalid predicate: //*[@foo\:bar] (Nokogiri::XML::XPath::SyntaxError)

有人有任何建议吗?

$ nokogiri -v
# Nokogiri (1.5.6)
--- 
nokogiri: 1.5.6
warnings: []

ruby: 
  version: 1.8.7
  engine: mri
  description: ruby 1.8.7 (2012-02-08 patchlevel 358) [universal-darwin11.0]
  platform: universal-darwin11.0
libxml: 
  loaded: 2.7.3
  compiled: 2.7.3
  binding: extension

这些是旧版本吗?

1 个答案:

答案 0 :(得分:2)

它应该工作。请参阅以下示例代码:

require 'nokogiri'
doc = Nokogiri::XML('<root xmlns:foo="http://www.example.com/"><abc foo:bar="hello"></abc></root>')
doc.xpath('//*[@foo:bar]')
# => #<Nokogiri::XML::Document:0x61ca74 name="document" children=[#<Nokogiri::XML::Element:0x61c63c name="root" children=[#<Nokogiri::XML::Element:0x61c3e4 name="abc" attributes=[#<Nokogiri::XML::Attr:0x61c36c name="bar" namespace=#<Nokogiri::XML::Namespace:0x61c088 prefix="foo" href="http://www.example.com/"> value="hello">]>]>]>