我有以下XML:
<xmlRequest>
<stats>
<match mid='40704828'>
<match_stats>
<ms aid='254664' cli_name='Hero_Engineer'>
<stat name='nickname'>lethallynx</stat>
<stat name='level'>11</stat>
</ms>
<ms aid='354522' cli_name='Hero_Devourer'>
<stat name='nickname'>AbendrothA</stat>
<stat name='level'>12</stat>
</ms>
</match_stats>
</match>
</stats>
</xmlRequest>
我正在尝试使用以下代码提取nickName和level的值:
XmlNodeList nodeList = doc.SelectNodes("//ms");
List<string> myList = new List<string>();
foreach (XmlNode node in nodeList)
{
XmlNode nodeNickName = node.SelectSingleNode("//stat[@name='nickname']/text()");
mylist.Add(nodeNickName.Value);
}
问题在于,虽然我可以看到使用下一组数据更新节点对象,但返回的值始终与第一个昵称相同。
所以nodeNickName.Value总是等于“lethallynx”。
有什么想法吗?
答案 0 :(得分:14)
//
xpath查询中的//stat[@name='nickname']/text()
选择根节点并从那里搜索。
您应该将./
替换为./stat[@name='nickname']/text()
,该{{1}}从当前节点进行搜索,为{{1}}
答案 1 :(得分:0)
在foreach
尝试:
string nickname = node.SelectSingleNode("stat[@name='nickname']").InnerText;
mylist.Add(nickname);