尝试在下面的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']");
然后确认您得到的正是一个结果。