环境:VS 2010,.NET 3.5
我正在开发一个从RESTful Web服务中提取数据的项目。几乎所有这些都正常工作,除了一个部分,它的值不正确。
以下是此部分代码中使用的XML示例:
<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<dataprovider>
<id>DP6</id>
<name>Query 1</name>
<dataSourceId>96390</dataSourceId>
<dataSourcePrefix>DS6</dataSourcePrefix>
<updated>2014-08-25T16:51:38.000-04:00</updated>
<duration>1</duration>
<isPartial>false</isPartial>
<rowCount>13</rowCount>
<flowCount>1</flowCount>
<dictionary>
<expression qualification="Dimension" dataType="String">
<id>DP6.DOa6</id>
<name>City</name>
<description>City located.</description>
<dataSourceObjectId>DS6.DOa6</dataSourceObjectId>
<formulaLanguageId>[City]</formulaLanguageId>
</expression>
</dictionary>
</dataprovider>
以下是代码:
private void loadElements(List<string> dps, int rptId)
{
string name = string.Empty;
string id = string.Empty;
string elementUrl = baseUrl + string.Format(C_WEBI_URL, rptId) + C_DP_URL;
foreach (string dpId in dps)
{
XmlDocument dpXml = getResponse(elementUrl + "/" + dpId);
//get the Expression nodes that define the objects on the report
XmlNodeList elementNodes = dpXml.SelectNodes("//expression");
if (elementNodes != null)
{
foreach (XmlNode node in elementNodes)
{
id = node.SelectSingleNode("//dataSourceObjectId").InnerText;
if (!elements.ContainsKey(id))
{
name = node.SelectSingleNode("//name").InnerText;
elements.Add(id, name);
}
}
}
}
}
我期望获得&#34; DP6.DOa6&#34;来自dataSourceObjectId,但它只返回&#34; DP6&#34;。而且我希望得到一个&#34; City&#34;从名称,但它返回&#34;查询1&#34;。当我在http://www.xpathtester.com/xpath使用上述XML测试XPath时,我得到了正确的值,但它在我的代码中不起作用。
有什么想法吗?
答案 0 :(得分:0)
您的名称查询的问题是XmlNode对象也保留外部xml,因此当您说//name
时,它将返回它在文档中找到的第一个名称元素。
正确的xpath语法为name
(无斜杠)。
至于dataSourceObjectId
我怀疑.
导致此行为可能会尝试InnerXml
而不是InnerText
完整示例:
foreach (XmlNode node in elementNodes)
{
id = node.SelectSingleNode("dataSourceObjectId").InnerXml; //I'm not sure if this will solve the problem.
if (!elements.ContainsKey(id))
{
name = node.SelectSingleNode("name").InnerText;
elements.Add(id, name);
}
}