我在我的项目中使用这样的库进行XML解析:
https://github.com/opticron/kxml/blob/master/source/kxml/xml.d
这是我的示例代码:
void main()
{
string xmlstring = cast(string)read("test.xml");
XmlNode newdoc = xmlstring.readDocument();
XmlNode[] searchlist = newdoc.parseXPath("//instancesSet/item");
foreach(list, searchlist)
{
string test = list.parseXPath("//instanceId").getCData();
writeln(test);
}
}
它不想编译:
$ dub
Performing "debug" build using dmd for x86_64.
kxml 1.0.0: target for configuration "library" is up to date.
test ~master: building configuration "application"...
source/app.d(23,56): Error: no property 'getCData' for type 'XmlNode[]'
dmd failed with exit code 1.
当我使用foreach
循环时,我认为它只从整个数组中获取一个值。因此,如果这是XmlNode[]
变量的数组,则只有一个变量应该只是XmlNode
(不是数组)。
为什么它仍然会看到阵列?如何使用getCData()
方法清除标记中的变量并将其放入string
?
答案 0 :(得分:1)
在循环中,list
实际上是XmlNode
,但其parseXPath()
返回XmlNode[]
。如果您只希望在每个list
中使用XPath查询的第一个结果,只需添加[0]
。
string test = list.parseXPath("//instanceId")[0].getCData();