我目前有一堆配置文件需要加载到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();将不再正常工作。这是我自己要改变的。
发布于 2013-07-20 01:20:39
您可以以声明的方式完成整个操作:
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-20 01:09:47
如果可以将Items更改为IEnumerable类型而不是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));https://stackoverflow.com/questions/17751751
复制相似问题