微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 解析多个子节点的xml和连接结果

我需要解析一个xml文件,需要加入节点’driver’的结果.每个’品牌’节点都是唯一的.样本xm​​l文件

<brand name = "ford">   
   <transport category="car">
      <driver name="John, Doe"/>
      <driver name="Jane, Doe"/>
    </transport>
</brand>
<brand name = "opel">
   <transport category="car">
      <driver name="Jerry, Smith"/>
      <driver name="Jeff, Perry"/>
     </transport>
</brand>

预期结果:

John, Doe - Jane, Doe
Jerry, Smith - Jeff, Perry

我的代码到目前为止:

    XmlTextReader reader = new XmlTextReader(@"D:\myfile.xml");

    while (reader.Read())
    {
        if (reader.Name == "brand")
            {
                XmlReader inner =  reader.ReadSubtree();
                while (inner.Read()) ;

                if (reader.Name == "driver")
                {
                    string drvNames = reader.GetAttribute("name");
                }   
            }
    }

我无法得到’司机’的结果.有一个或多个’驱动’节点.语言C#

解决方法:

你可以使用Linq到Xml:

var xdoc = XDocument.Load(@"D:\myfile.xml");
var query = from t in xdoc.Descendants("transport")
            select String.Join(" - ", t.Elements("driver")
                                      .Select(e => (string)e.Attribute("name")));

如果无法将整个文件加载到内存中:

XmlTextReader reader = new XmlTextReader(@"D:\myfile.xml");
List<string> result = new List<string>();

while (reader.Read())
{    
    if (reader.Name == "brand")
    {
        XmlReader inner = reader.ReadSubtree();
        List<string> names = new List<string>();

        while (inner.Read())
        {
            if (reader.Name == "driver")
                names.Add(reader.GetAttribute("name"));
        }

        if (names.Any())
            result.Add(String.Join(" - ", names));
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。