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(); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |