我需要使用XPath节点的子节点,因为我想“钻”到一个节点的子节点。下面是我想要的代码:红宝石,libxml的获得匹配的XPath
xml_ns = 'Document:http://www.google.com/books/'
xml_document = XML::Document.file('./test_pages/test.xml')
book_xpath = '//Document:View/Document:Books'
book_title_xpath = '//Document:Title'
xml_document.find(book_xpath, xml_ns).each() { | item |
puts item
item.find(book_title_xpath, xml_ns).each() { |item2|
puts '========================'
puts 'name: ' + item2.content().strip()
}
}
这里是一个XML片段
<Document xmlns="http://www.google.com/books/">
<View>
<Books>
<Title>pragmatic programming</Title>
</Books>
<Comics>
<Title>x-men</Title>
</Comics>
</View>
</Document>
先找工作找到并返回书节点。然而,第二个find(“//文件:标题”)返回所有标题节点的文件即使我只是在找到的节点搜索。
为什么会发生这种情况?我已经厌倦修改第二个XPath了,但是我已经厌倦了。有什么建议?
THX,以为我已经试过了,但我想我没有。 – 2009-10-26 13:13:55