2013-04-26 63 views
2

我想使用UniVerse的XDOM函数来解析XML文件,但我无法正确解析使用默认命名空间的XML。它可以正确处理没有名称空间或命名空间的XML,但是如果存在默认名称空间,则所有xPath都无法找到它们应该匹配的节点。UniVerse XDOM使用默认命名空间的问题

举一个简单的例子,我,试图解析这个XML:

<?xml version="1.0" encoding="ISO-8859-1"?> 
<bookstore xmlns="http://www.example.com"> 
    <book category="COOKING"> 
     <title lang="en">Everyday Italian</title> 
     <author>Giada De Laurentiis</author> 
     <year>2005</year> 
     <price>30.00</price> 
    </book> 
    <book category="CHILDREN"> 
     <title lang="en">Harry Potter</title> 
     <author>J K. Rowling</author> 
     <year>2005</year> 
     <price>29.99</price> 
    </book> 
    <book category="WEB"> 
     <title lang="en">Learning XML</title> 
     <author>Erik T. Ray</author> 
     <year>2003</year> 
     <price>39.95</price> 
    </book> 
</bookstore> 

有了这个代码:

PROGRAM XDOM.TEST 
$INCLUDE SYSCOM XML.H 

    OPEN "XML" TO F.XML ELSE STOP "OPEN FAILED" 
    READ XML FROM F.XML, 'TEST.xml' ELSE STOP "READ FAILED" 

    EXIT.PROG = @FALSE 

    CONVERT @FM TO CHAR(10) IN XML 
    IF NOT(EXIT.PROG) AND XDOMOpen(XML, XML.FROM.STRING, XDOM) # XML.SUCCESS THEN GOSUB XML.ERR 
    IF NOT(EXIT.PROG) AND XDOMLocate(XDOM, '/bookstore/book[@category="CHILDREN"]', 'xmlns=http://www.example.com', XNODE) # XML.SUCCESS THEN GOSUB XML.ERR 
    IF NOT(EXIT.PROG) AND XDOMEvaluate(XNODE, './author', 'xmlns=http://www.example.com', AUTHOR) # XML.SUCCESS THEN GOSUB XML.ERR 
    IF NOT(EXIT.PROG) then PRINT AUTHOR 
STOP 

XML.ERR: 

    XML.CODE = '' 
    XML.ERR = '' 
    EXIT.PROG = @TRUE 
    IF XMLGetError(XML.CODE, XML.ERR) = XML.SUCCESS THEN 
     PRINT XML.CODE 
     PRINT XML.ERR 
    END 

    RETURN 
END 

当我为这段代码运行,我得到的输出:

10 
The location path '/bookstore/book[@category="CHILDREN"]' was not found. 

但是,如果我删除 “的xmlns = http://www.example.com” 命名空间,它工作正常。

回答

2

经过我自己的搜索后,我发现这实际上是UniVerse的XDOM解析器本身的一个错误。有人亲切地记录了解决方法here。您可以通过给默认命名空间命名来“愚弄”解析器进入工作状态。他们还指出,您不能在名称空间映射中使用双引号。

就个人而言,我更喜欢简单的解决方案,只是在解析它之前手动删除违规名称空间。添加此行上述程序修复了问题,尽管在一个非常哈克的方式:

XML = CHANGE(XML, ' xmlns="http://www.example.com"', '') 

这样,您就不必把不必要的前缀所有的XPath节点上。这可能并不总是一个选项,取决于你如何获得XDOM句柄。

+0

感谢您提供各种解决方案。我在你提供的链接中使用了解决方案,因为它不涉及更改XML文档,但两者都可以正常工作。 – 2013-05-16 23:44:24