我一直在寻找一种方法来查找具有特定属性的元素节点,并找到: “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
这些是旧版本吗?
答案 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">]>]>]>