列出<T> OrderBy字母顺序

倾然丶 夕夏残阳落幕 提交于 2020-02-26 21:24:26

我在Framework 3.5上使用C#。 我想快速排序通用List<T> 。 为了这个例子,假设我有一个具有lastname属性的Person类型的List。 如何使用lambda表达式对此List进行排序?

List<Person> people = PopulateList();
people.OrderBy(???? => ?????)

#1楼

您可以使用此代码段:

var New1 = EmpList.OrderBy(z => z.Age).ToList();

其中New1List<Employee>

EmpListList<Employee>变量。

zEmployee类型的变量。


#2楼

people.OrderBy(person => person.lastname).ToList();

#3楼

您是否需要对列表进行分类,或者只是列表内容的有序序列? 后者更容易:

var peopleInOrder = people.OrderBy(person => person.LastName);

要进行排序,您需要IComparer<Person>Comparison<Person> 。 为此,您可能希望在MiscUtil中考虑ProjectionComparer

(我知道我一直把MiscUtil搞定 - 它只是保持相关......)


#4楼

如果您的意思是就地排序(即列表已更新):

people.Sort((x, y) => string.Compare(x.LastName, y.LastName));

如果你的意思是新的清单:

var newList = people.OrderBy(x=>x.LastName).ToList(); // ToList optional

#5楼

这是一个通用的分拣机。 用下面的开关调用。

dvm.PagePermissions是我的ViewModel类型为List T的属性,在这种情况下,T是一个名为page_permission的EF6模型类。

dvm.UserNameSortDir是viewmodel上的字符串属性,用于保存下一个排序方向。 在视图中被动态使用的那个。

switch (sortColumn)
{
    case "user_name":
        dvm.PagePermissions = Sort(dvm.PagePermissions, p => p.user_name, ref sortDir);
        dvm.UserNameSortDir = sortDir;
        break;
    case "role_name":
        dvm.PagePermissions = Sort(dvm.PagePermissions, p => p.role_name, ref sortDir);
        dvm.RoleNameSortDir = sortDir;
        break;
    case "page_name":
        dvm.PagePermissions = Sort(dvm.PagePermissions, p => p.page_name, ref sortDir);
        dvm.PageNameSortDir = sortDir;
        break;
}                 


public List<T> Sort<T,TKey>(List<T> list, Func<T, TKey> sorter, ref string direction)
    {
        if (direction == "asc")
        {
            list = list.OrderBy(sorter).ToList();
            direction = "desc";
        }
        else
        {
            list = list.OrderByDescending(sorter).ToList();
            direction = "asc";
        }
        return list;
    }
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!