列出<string> C#自定义排序。数字后下划线

时间:2015-07-09 11:00:14

标签: c# sorting stringcomparer

我有一个清单:&#34; a_a&#34;,&#34; a1a&#34;,&#34; aaa&#34;。

我需要按照以下方式对其进行排序:&#34; a1a&#34;,&#34; a_a&#34;,&#34; aaa&#34;。

换句话说,我需要&#39; _&#39;符号出现在数字之后但在字母之前。

我知道可以使用自定义Comparer,但我还没有找到任何解决这个问题的好方法,只有肮脏的黑客,例如:

Compare(string x, string y){

return Comparer.Default.Compare(x.Replace("_", "9z"), y.Replace("_", "9z"));

}

2 个答案:

答案 0 :(得分:2)

根据标准ASCII表:

  '0'..'9' have codes 0x30..0x39
  '_'      -/-        0x5F
  'a'..'z' -/-        0x61..0x7A

因此,由于代码的顺序正确,您可以使用序数比较:

  List<String> list = new List<string> {
    "a1a", "a_a", "aaa"
  };

  list.Sort((Comparison<String>) (
    (String left, String right) => {
       return String.CompareOrdinal(left, right);
    }
  ));

  ...
  // a1a, a_a, aaa
  Console.Write(String.Join(", ", list)); 

答案 1 :(得分:0)

这是一个自定义字符串比较器,它将采用char比较器,因此您可以根据需要比较字符。话虽这么说,但在实现自己的比较器之前,请确保StringComparer.Ordinal不能完成工作。

public class CustomStringComparer : IComparer<string>
{
    readonly IComparer<char> charComparer;
    public CustomStringComparer(IComparer<char> charComparer)
    {
        this.charComparer = charComparer;
    }
    public int Compare(string a, string b)
    {
        int result = 0;
        for (int i = 0; (i < a.Length || i < b.Length) && result == 0 ; i++)
        {
            if (i >= a.Length || i >= b.Length)
            {
                return i >= a.Length ? -1 : 1;
            }
            result = charComparer.Compare(a[i], b[i]);
        }
        return result;
    }
}