Сортировка списка с помощью строки без Linq
есть ли способ сортировать List<T>
используя строку "Name desc"
(как и DataTable.DefaultView.Sort
), а не Linq?
Я пытаюсь заменить DataTables
С Lists
и мне нужно, чтобы это было совместимо со старым кодом.
решение
используя код V4Vendetta, я смог создать этот метод расширения, тесты, похоже, показывают, что он работает.
public static void SortByString<T>(this List<T> list, string sortString)
{
if (sortString == null) return;
List<string> SortGroups = sortString.Split(',').ToList();
for (int i = SortGroups.Count - 1; i >= 0; i--)// sort from the last group first
{
string tempColumn = SortGroups[i].Trim().Split(' ')[0];
bool isAsc = SortGroups[i].Trim().Split(' ').Length > 1 ? SortGroups[i].Trim().Split(' ')[1].ToLower() == "asc" ? true : false : true;
PropertyInfo propInfo = typeof(T).GetProperty(tempColumn);
if (propInfo == null) // if null check to make sure its not just a casing issue.
{
foreach (PropertyInfo pi in typeof(T).GetProperties())
{
if(pi.Name.ToLower() == tempColumn.ToLower())
{
tempColumn = pi.Name;
propInfo = typeof(T).GetProperty(tempColumn);
break;
}
}
}
if (propInfo != null)
{
Comparison<T> compare = delegate(T a, T b)
{
object valueA = isAsc ? propInfo.GetValue(a, null) : propInfo.GetValue(b, null);
object valueB = isAsc ? propInfo.GetValue(b, null) : propInfo.GetValue(a, null);
return valueA is IComparable ? ((IComparable)valueA).CompareTo(valueB) : 0;
};
list.Sort(compare);
}else{
throw new IndexOutOfRangeException("Property: '" + tempColumn + "', does not exist in '" + typeof(T).ToString() + "'");
}
}
}
5 ответов
Я пробовал что-то на этих линиях, возможно, вам нужно импровизировать его cit для вашей потребности
private List<Employee> CreateSortList<T>(
IEnumerable<Employee> dataSource,
string fieldName, SortDirection sortDirection)
{
List<Employee> returnList = new List<Employee>();
returnList.AddRange(dataSource);
// get property from field name passed
System.Reflection.PropertyInfo propInfo = typeof(T).GetProperty(fieldName);
Comparison<Employee> compare = delegate(Employee a, Employee b)
{
bool asc = sortDirection == SortDirection.Ascending;
object valueA = asc ? propInfo.GetValue(a, null) : propInfo.GetValue(b, null);
object valueB = asc ? propInfo.GetValue(b, null) : propInfo.GetValue(a, null);
//comparing the items
return valueA is IComparable ? ((IComparable)valueA).CompareTo(valueB) : 0;
};
returnList.Sort(compare);
return returnList;
}
вам нужно пройти в соответствующем направлении сортировки и имя поля, которое будет свойством класса (в моем случае Employee)
надеюсь, что это помогает
список имеет какие-то методы, а некоторые берут Comparison<T>
Что вы можете реализовать, чтобы иметь пользовательское сравнение сортировки
насколько я знаю, для этого типа поиска нет встроенной поддержки. Так что тебе придется написать свою собственную.
не должно быть слишком сложно разобрать строку. Разделите его на запятые (,), если у вас есть строка сортировки, например "name asc, age desc", и рассматривайте каждый как имя и направление. Затем вы можете использовать отражение типа T, чтобы найти свойство для сортировки и построить метод, который выполняет необходимое сравнение.
посмотрите на эту статью на codeplex для пример: http://www.codeproject.com/KB/linq/dynamite_dynamic_sorting.aspx
У меня был успех с динамической библиотекой запросов linq в прошлом: http://weblogs.asp.net/scottgu/archive/2008/01/07/dynamic-linq-part-1-using-the-linq-dynamic-query-library.aspx
посмотрите на пространство имен специализированных коллекций. Там должен быть отсортированный список.