尝试在下面的XML文件示例中检索Rank的值...
我通过的路径可以通过SelectNodes方法正常工作,除了当我将属性添加到路径时,代码将跳过foreach循环

感谢您提供有关如何解决此问题的帮助。
另外,我正在根据Sub ID和Rank ID的特定属性寻找Rank元素的一个值及其值,因此不需要循环,但这是我知道的唯一方法

XML档案:


<Model>

<BookStore>
    <Book>
      <Sub ID="Science">
        <Rank ID="Chemistry">Value1</Rank>
        <Rank ID="Physics">Value2</Rank>
      </Sub>
    </Book>
</BookStore>

</Model>




C#代码:

var myDoc = new XmlDocument();
myDoc.Load(MapPath("myXML.xml"));

XmlNodeList rankList = myDoc.SelectNodes("/Model/BookStore/Book/Sub[@ID='Science']/Rank");  // Science can be any other variable
foreach (XmlNode myRankNode in rankList)
{
    if (myRankNode.Attributes["ID"].Value.ToString() == "Physics") // Physics can be any other variable
    {
        myValue = myRankNode.InnerText;
    }

}

最佳答案

您应该能够做到这一点:

 myDoc.SelectNodes("/Model/BookStore/Book/Sub[@ID='Science']/Rank[@ID='Physics']");


然后确认您得到的正是一个结果。

10-01 23:31
查看更多