0

我目前有一堆配置文件需要加载到 IOrderedEnumerable 我当前的方法如下所示:

foreach (var item in configFiles)
{
    XDocument myxml = XDocument.Load(item);
    var items = myxml.Root.Elements("Item");
    Items = items.OrderBy(x => x.Attribute("ID").Value);
    ItemsLength += Items.Count();              
}

问题是,而不是Items等于items.OrderBy(x => x.Attribute("ID").Value)我想将它加入到当前存在的 IOrderedEnumerable 的末尾,所以每次加载新的 XDocument 并从中获取所有元素时我都不会覆盖它。我该怎么做?

编辑:我知道如果我改变这ItemsLength += Items.Count();将不再正常工作。那是我自己会改变的。

4

2 回答 2

2

您可以以声明方式完成所有操作:

Items = configFiles.Select((item, index) => new { Doc = XDocument.Parse(item),
                                                  Index = index })
                   .SelectMany(pair => pair.Doc.Root.Elements("Item")
                                           .Select(x => new { Item = x, 
                                                              Index = pair.Index }))
                   .OrderBy(pair => pair.Index)
                   .ThenBy(pair => (string) pair.Attribute("ID"))
                   .Select(pair => pair.Item);

这基本上找到了所有元素,但记住了每个元素所在的配置。

或者,只需创建一个List<XElement>并添加每个项目的内容:

var items = new List<XElement>();
foreach (var item in configFiles)
{
    items.AddRange(XDocument.Parse(item)
                            .Root.Elements("Item")
                            .OrderBy(x => (string) x.Attribute("ID")));
}
Items = items;

在某些方面不太优雅,但可能更容易理解:)

于 2013-07-19T17:20:39.490 回答
1

如果您可以更改Items为 typeIEnumerable而不是IOrderedEnumerable,则可以使用Concat

Items = Items.Concat(items.OrderBy(x => x.Attribute("ID").Value));

这将使项目ID在他们自己的文档中进行排序。

请注意,Concat在循环中使用可能会影响性能。你最好声明Items为,并在每次迭代结束时IList调用:ToList

Items.AddRange(items.OrderBy(x => x.Attribute("ID").Value));
于 2013-07-19T17:09:47.020 回答