于是,我就在下面的XML使用F# XML parsing post(从uclassify API):解析XML时,文件有xmlns属性
<?xml version="1.0" encoding="UTF-8" ?>
<uclassify xmlns="http://api.uclassify.com/1/ResponseSchema" version="1.01">
<status success="true" statusCode="2000"/>
<readCalls>
<classify id="cls1">
<classification textCoverage="1">
<class className="happy" p="0.912929"/>
<class className="upset" p="0.0870707"/>
</classification>
</classify>
</readCalls>
</uclassify>
的代码是一样的东西:
let doc =
Xdocument.Load file
doc.Element(xn "uclassify")
.Element(xn "readCalls")
.Element(xn "classify")
.Element(xn "classification")
.Element(xn "class").Attribute(xn "p")
这确实不行!!!似乎无法完成解析。然而,除去属性xmlns="http://api.uclassify.com/1/ResponseSchema" version="1.01"
使得它的工作:
let doc =
Xdocument.Load file
let test = IO.File.ReadAllText(file).Replace("xmlns=\"http://api.uclassify.com/1/ResponseSchema\" version=\"1.01\"","")
XDocument.Parse(test)
doc.Element(xn "uclassify")
.Element(xn "readCalls")
.Element(xn "classify")
.Element(xn "classification")
.Element(xn "class").Attribute(xn "p")
注意这个问题似乎与Why must I remove xmlns attribute ...。所以问题是为什么我必须删除xmlns属性?我应该使用什么来分析具有xmlns属性的xml?
谢谢
这也将是每一个如此稍快;-)。 – 2011-05-04 15:54:19