OrderBy / ThenBy循环 – C#中的嵌套列表

前端之家收集整理的这篇文章主要介绍了OrderBy / ThenBy循环 – C#中的嵌套列表前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个嵌套列表,
List<List<String>> intable;

我想对所有列进行排序.问题是列数取决于用户输入.

排序列表像这样工作正常(假设为此示例4列)

var tmp = intable.OrderBy(x => x[0]);
tmp = tmp.ThenBy(x => x[1]);
tmp = tmp.ThenBy(x => x[2]);
tmp = tmp.ThenBy(x => x[3]);
intable = tmp.ToList();

但是,当我把它放在一个循环中,像这样:

var tmp = intable.OrderBy(x => x[0]);
for (int i = 1; i <= 3; i++)
{
        tmp = tmp.ThenBy(x => x[i]);
}
intable = tmp.ToList();

它不再正常工作,仅排列第四列.

解决方法

这是访问修改关闭的情况.将代码更改为此,它将工作:
var tmp = intable.OrderBy(x => x[0]);
for (int i = 1; i <= 3; i++) {
    var thisI = i;
    tmp = tmp.ThenBy(x => x[thisI]);
}
intable = tmp.ToList();

Eric Lippert写了一篇描述这个问题的two-part article.因为LINQ只是在调用ToList()时被评估时才使用最后一个值,所以它根本无法正常工作.和你写的一样:

var tmp = intable.OrderBy(x => x[0]);
tmp = tmp.ThenBy(x => x[3]);
tmp = tmp.ThenBy(x => x[3]);
tmp = tmp.ThenBy(x => x[3]);
intable = tmp.ToList();

猜你在找的MsSQL相关文章