1
 <root>
    <level1>
        <item id="1" date="" name="" >
        <item id="2" date="" name="" >
        <item id="3" date="" name="" >
        <item id="4" date="" name="" >
        <item id="5" date="" name="" >
    </level1>
 </root>

我有一个像上面那样的 xml 结构。

我用了

XmlNodeList xnList = xmlDoc.SelectNodes("/level1");

如果我如上所述使用 xmlnodelist,我怎样才能专门只获取 id="3" 的元素?

如果我可以将所有元素作为元素存储在 xnlist 中,或者更有用?

4

2 回答 2

2

除了来自@LB 的出色回答外,我还使用 Linq,我个人认为它更具可读性:

xdoc.Element("level1")
    .Descendants("item")
    .Where(x => x.Attribute("id").Value == "3").First();

但这一切都取决于你的风格;)

于 2012-11-29T21:13:32.453 回答
2
XmlNodeList xnList = xmlDoc.SelectNodes("//level1/item[@id='3']");

如果你想使用Linq To Xml

var xDoc = XDocument.Parse(xmlstring); // XDocument.Load(filename)
var items = xDoc.Descendants("level1")
                .First()
                .Elements("item")
                .Select(item => new { 
                                    ID = item.Attribute("id").Value, 
                                    Name = item.Attribute("name").Value 
                                })
                .ToList();

你甚至可以结合 XPath 和 Linq2Xml

var item2 = xDoc.XPathSelectElements("//level1/item")
                .Select(item => new { 
                                    ID = item.Attribute("id").Value, 
                                    Name = item.Attribute("name").Value 
                                })
                .ToList();
于 2012-11-29T21:03:22.650 回答