首页 > 解决方案 > 使用 XML 中的某个节点过滤结果

问题描述

我有一个像下面这样的 xml

<Orders>
<Order>
<ABC>defe</ABC>
</Order>

<Order>
<ABC>asa</ABC>
<YYY>ee1@ee.com</YYY>
</Order>

<Order>
<ABC>tyty</ABC>
<YYY>ee1@ee.com</YYY>
</Order>
</Orders>

我想取出具有节点 YYY 的记录,就像在上面的情况下,查询应该返回两组顺序,其中包含 YYY 节点。第一条记录应该从过滤结果中排除。结果应该是

<Order>
<ABC>asa</ABC>
<YYY>ee1@ee.com</YYY>
</Order>

<Order>
<ABC>tyty</ABC>
<YYY>ee1@ee.com</YYY>
</Order>

请帮帮我。

标签: c#xmllinq-to-xml

解决方案


请参阅下面的代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Linq;

namespace ConsoleApplication116
{
    class Program
    {
        const string FILENAME = @"c:\temp\test.xml";
        static void Main(string[] args)
        {
            XDocument doc = XDocument.Load(FILENAME);

            List<XElement> orders = doc.Descendants("Order").Where(x => x.Element("YYY") != null).ToList();
        }
    }
}

推荐阅读