3

我需要使用 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>  

第一个查找工作查找并返回 Books 节点。然而,即使我只在找到的节点中搜索,第二个 find('//Document:Title') 也会返回文档中的所有标题节点。

为什么会发生这种情况?我已经厌倦了修改第二个 XPath,但我厌倦了任何工作。有什么建议吗?

4

2 回答 2

3

返回的xml_document节点永远不会从原始源中断开。您始终可以前后移动,唯一的区别是“指针”位于当前找到的节点处。

您需要做的是更改您的 XPath,使其不执行“完整文档搜索”:特殊//(即“descendant-or-self”)从根开始并遍历所有节点。相反,请使用以下内容:

book_title_xpath = 'Document:Title'

这将返回名为“Title”的第一个孩子。如果您需要从 Book 节点搜索所有子节点,您可以执行以下操作:

book_title_xpath = './/Document:Title'

其中添加了.and 表示“从当前节点开始并搜索当前节点和所有后代”

于 2009-10-25T20:52:52.767 回答
0

尝试

book_title_xpath = 'Title'

于 2009-10-25T20:56:42.383 回答