У меня есть общий
List<MyClass>
, где MyClass
имеет свойство InvoiceNumber
, которое содержит такие значения, как:
200906/1
200906/2
..
200906/10
200906/11
200906/12
Мой список привязан к
BindingList<T>
, которая поддерживает сортировку с помощью linq:
protected override void ApplySortCore(
PropertyDescriptor property, ListSortDirection direction)
{
_sortProperty = property;
_sortDirection = direction;
var items = this.Items;
switch (direction)
{
case ListSortDirection.Ascending:
items = items.OrderByDescending(x => property.GetValue(x)).ToList();
break;
case ListSortDirection.Descending:
items = items.OrderByDescending(x => property.GetValue(x)).ToList();
break;
}
this.Items = items;
}
Однако компаратор по умолчанию сортируется (как предполагается) следующим образом:
200906/1
200906/10
200906/11
200906/12
200906/2
, что в данном случае неприятно.
Теперь я хочу использовать свой собственный IComparer<T>
с этим. Это выглядит так:
public class MyComparer : IComparer<Object>
{
public int Compare(Object stringA, Object stringB)
{
String[] valueA = stringA.ToString().Split('/');
String[] valueB = stringB.ToString().Split('/');
if(valueA .Length != 2 || valueB .Length != 2)
return String.Compare(stringA.ToString(), stringB.ToString());
if (valueA[0] == valueB[0])
{
return String.Compare(valueA[1], valueB[1]);
}
else
{
return String.Compare(valueA[0], valueB[0]);
}
}
}
и изменил код ApplySortCore
, чтобы использовать это IComparer
:
case ListSortDirection.Ascending:
MyComparer comparer = new MyComparer();
items = items.OrderByDescending(
x => property.GetValue(x), comparer).ToList();
break;
Когда я отлаживаю свой код, я вижу, что MyComparer.Compare(object, object)
вызывается несколько раз и возвращает правильные значения (-1, 0, 1) для метода сравнения.
Но мой список все еще отсортирован по "неправильному" пути. Я что-то пропустил? Понятия не имею.