排序列表<特定对象类型> </特定对象类型>

时间:2012-07-03 05:12:37

标签: c# .net ilist

  

可能重复:
  Sorting an IList in C#

我有一个IList<Keyword>,其中Keyword是一个包含标题(字符串)和键(数字)的类。我希望根据关键点对这个IList进行排序。是否有可以使用的内置C#功能?

8 个答案:

答案 0 :(得分:2)

您需要添加:using System.Linq;

IList<keyword> sortedList = list.OrderBy(r => r.key).ToList();

或者您可以尝试:

  IList<keyword> sortedList2 = (from r in list
                                orderby r.key
                                select r).ToList();

答案 1 :(得分:0)

<强>更新 您可以使用OrderByOrderByDescending

var sort = list.OrderBy(x=> x.key);

或者

var reverseSort = list.OrderByDescending(x=> x.key);

答案 2 :(得分:0)

以下是OrderByDescending的链接,如果您有IList<YourType>IEnumerable<YourType>,则可以使用该链接。

 var sorted = list.OrderByDescending(x=> x.key);

答案 3 :(得分:0)

您可以使用Linq Enumerable.OrderBy Method

var result = listOfObject.OrderBy(item => item.key).ToList();

按降序排序使用Enumerable.OrderByDescending Method ..

如果您使用的是.net framework 3.0及更高版本,请在顶部添加using System.Linq并尝试使用上述扩展方法。

答案 4 :(得分:0)

是的,借助扩展方法,您可以轻松实现此目标

var sortelist = list.OrderBy(x=>x.PropertyName).ToList();

MSDN:

对数据Ascending进行排序:

Enumerable.OrderBy Method (IEnumerable, Func) - 根据键按升序对序列元素进行排序。

对数据Descending进行排序:

Enumerable.OrderByDescending Method (IEnumerable, Func) - 根据键按降序对序列的元素进行排序。

答案 5 :(得分:0)

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web.UI.WebControls;
using dynamic = System.Linq.Dynamic;
using System.Linq.Expressions;

namespace Lib.Extensions
{
    public static class Utils
    {
        /// <summary>
        /// Sorts by Model property with dynamic expression
        /// </summary>
        /// <param name="list"> </param>
        /// <param name="propertyName"></param>
        /// <param name="sortDirection"> </param>
public static List<TObject> SortByModelProperty<TObject, TProperty>(this List<TObject> list, Expression<Func<TObject, TProperty>> property, SortDirection sortDirection)
    {
        string propertyName = GetPropertyName(property);
        string exp1 = string.Format("model.{0}", propertyName);

        var p1 = Expression.Parameter(typeof(TObject), "model");
        var e1 = System.Linq.Dynamic.DynamicExpression.ParseLambda(new[] { p1 }, null, exp1);

        if (e1 != null)
        {
            if (sortDirection == SortDirection.Ascending)
            {
                var result = list.OrderBy((Func<TObject, TProperty>)e1.Compile()).ToList();
                return result;
            }
            else
            {
                var result = list.OrderByDescending((Func<TObject, TProperty>)e1.Compile()).ToList();
                return result;
            }
        }
        return list;
    }

    private static string GetPropertyName<TObject, TProperty>(Expression<Func<TObject, TProperty>> property)
    {
        MemberExpression memberExpression = (MemberExpression)property.Body;
        PropertyInfo propertyInfo = (PropertyInfo)memberExpression.Member;

        return propertyInfo.Name;
    }

    }
}

您应该添加System.Linq.Dynamic.You可以找到它Nuget包管理器。  我认为这种扩展方法可以帮助你。

答案 6 :(得分:0)

试试这个:

var sorted = from c in list orderby c.Key select c;

答案 7 :(得分:-1)

如果您可以控制Keyword类并考虑订购其“自然”排序的数字,请让Keyword实现IComparable<Keyword>接口。

如果您无法控制该类,或者您不希望将此排序指定为自然/默认,请创建一个实现IComparator<Keyword>接口的类。

编辑:或者使用LINQ获得更简单,更快捷的答案。被困在Java太久了!

var sorted = keywords.OrderBy(k => k.Key);