加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2020-12-12 16:08:57 所属栏目:MsSql教程 来源:网络整理
导读:我有一个嵌套列表, ListListString 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 =
我有一个嵌套列表,
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();

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读