用Nokogiri获取节点的兄弟姐妹

时间:2013-05-30 04:53:15

标签: ruby nokogiri

有没有办法在节点中找到特定值然后返回其所有兄弟值?

例如,我想找到包含ID 5678的id节点,然后获取电子邮件地址以及与ID 5678相关联的所有图像。

Nokogiri::XML.parse(File.open('info.xml'))

这是一个示例XML文件。

<xmlcontainer>
  <details>
    <id>1234</id>
    <email>sdfsdf@sdasd.com</email>
    <image>images/1.jpg</image>
    <image>images/2.jpg</image>
    <image>images/3.jpg</image>
  </details>
  <details>
    <id>5678</id>   
    <email>zzzz@zzz.com</email>
    <image>images/4.jpg</image>
    <image>images/5.jpg</image>
  </details>
  <details>
    <id>9011</id>   
    <email>aaaa@aaa.com</email>
    <image>images/6.jpg</image>
    <image>images/7.jpg</image>
  </details>
</xmlcontainer>

2 个答案:

答案 0 :(得分:6)

您可以使用~,这是css通用兄弟选择器:

doc.search('id[text()="5678"] ~ *').map &:text
#=> ["zzzz@zzz.com", "images/4.jpg", "images/5.jpg"]

将css与xml一起使用有点奇怪,但它更容易查看(比xpath更容易)。

答案 1 :(得分:4)

require 'nokogiri'
doc = Nokogiri::XML.parse(File.open('info.xml'))
details = doc.css('details').find{|node| node.css('id').text == "5678"}
email = details.css('email').text # => "zzzz@zzz.com"
images = details.css('image').map(&:text) # => ["images/4.jpg", "images/5.jpg"]

更新:有更短的,可以说是更好的方法来获取您想要的details节点:

details = doc.at('details:has(id[text()="5678"])')

details = doc.search('id[text()="5678"] ~ *')

这些都是pguardiario的礼貌。