3

我正在寻找一种方法来查找具有特定属性的元素节点并发现:“使用 Nokogiri 获取包含特定属性名称的元素中的所有节点

但是,当属性有冒号时它不起作用,例如“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

这些是旧版本吗?

4

1 回答 1

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">]>]>]>
于 2013-09-23T09:03:40.607 回答