我在我的项目中使用这样的库来进行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
发布于 2015-10-20 09:17:07
在循环中,list实际上是一个XmlNode,但它的parseXPath()返回XmlNode[]。如果只想在每个list中处理XPath查询的第一个结果,只需添加[0]即可。
string test = list.parseXPath("//instanceId")[0].getCData();https://stackoverflow.com/questions/33226360
复制相似问题