有没有办法在节点中找到特定值然后返回其所有兄弟值?
例如,我想找到包含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>
答案 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的礼貌。