OrderBy со шведскими буквами

У меня есть список моего пользовательского класса Customer, и я хочу сортировать их по алфавиту по названию. Поэтому я написал

myList = myList.OrderByDescending(x => x.Title).ToList<Customer>();

Теперь проблема в том, что этот метод не поддерживает шведский способ сортировки букв å, ä, ö. Они должны появиться в конце после буквы z, но они этого не делают.

Итак, я применил метод обхода, который заменяет шведские буквы перед заказом, а затем изменяет их обратно. Похоже, но это довольно медленно. Может ли кто-нибудь подумать о лучшем способе?

private List<Customer> OrderBySwedish(List<Customer> myList)
    {
        foreach (var customer in myList)
        {
            customer.Title = customer.Title.Replace("å", "zzz1").Replace("ä", "zzz2").Replace("ö", "zzz3").Replace("Å", "Zzz1").Replace("Ä", "Zzz2").Replace("Ö", "Zzz3");
        }

        myList= myList.OrderBy(x => x.Title).ToList<Customer>();

        foreach (var customer in myList)
        {
            customer.Title = customer.Title.Replace("zzz1", "å").Replace("zzz2", "ä").Replace("zzz3", "ö").Replace("Zzz1", "Å").Replace("Zzz2", "Ä").Replace("Zzz3", "Ö");
        }
        return myList;
    }

Ответ 1

Вы можете использовать специфическую для культуры StringComparer, см. здесь.

CultureInfo culture = new CultureInfo("sv-SE");
var result = myList.OrderByDescending(x => 
               x.Title, StringComparer.Create(culture, false));

Ответ 2

Установите свойство Thread.CurrentCulture в правильную культуру.

Ответ 3

В моем случае: _Мой список сортировки имеет значение, которое было закодировано. Это делает мой заказ неправильным. Добавить декодированное решение моих проблем!

Ответ 4

Обходной путь, который я нашел для некоторой схожей проблемы, состоял в том, чтобы иметь вторичное поле, содержащее преобразованную версию данных.
В моем случае мы имели person.Name и person.SearchName, где SearchName был Name преобразован, чтобы не иметь диакритики.

Но это был только лучший подход (AFAIK), потому что нам нужен быстрый поиск/фильтрация db, а затем создание только соответствующих результатов.
Если у вас уже есть объекты в памяти, я бы посоветовал пойти с одним из других подходов; и не.