C#中字符串排序的问题和解决方法
先说下问题,简单的说就是一组数据
String[] data = new string[]{ "-3A01","-03A02", "-301","-302", "-201","-202", "-101","-102", "101","102", "201","202", "301","302", "3A01","3A02", "T3A01","T3A02" };
我想按照字符串排序,排序原理,我理所应当的想到是单个字符比较大小后,进行排序,但是我排序后结果是:
-03A02 |
101 |
-101 |
102 |
-102 |
201 |
-201 |
202 |
-202 |
301 |
-301 |
302 |
-302 |
3A01 |
-3A01 |
3A02 |
T3A01 |
首先我感觉排序顺序错了,因为按照预想的规则应该负号开头的字符串是在一起的才对。
然后我查找资料在MSDN上看到这样一段话:
使用字词排序规则的操作执行一个区域敏感比较,在这个比较中可能会为非字母数字的 Unicode 字符分配特殊权重。 使用字词排序规则和特定区域的约定,连字符(“-”)的权重可能非常小,因此“coop”和“co-op”在排序列表中是紧挨着出现的。
然后基本就明白了,在C#中“-”负号的权限因为英文本身的缘故,自动降低的权限,导致这样的排序问题出现。
随后我寻找了下解决方案:
在List<T>.sort方法中可以自己写排序方法,或者实现一个类继承IComparer这个接口,在实现的Compare中比较字符串的语句可以这样写:
string.Compare(x, y, StringComparison.Ordinal);
第三个参数给出的解释是“比较字符串使用序号排序规则”
如此比较“-”就不会自动被降低权限了。
还有一种可能性就是不存在这样的sort方法给我们用,比如DataTable中,在DataTable中我选择了这样的方法:
public class String2 : IComparable, IComparable<String2> { private string val; public String2(string str) { val = str; } public override string ToString() { return this.val; } public int CompareTo(String2 obj) { if (obj == null) return 1; else return string.Compare(val, obj.val, StringComparison.Ordinal); } public int CompareTo(object obj) { String2 other = obj as String2; if (other == null) return 1; else { return string.Compare(val, other.val, StringComparison.Ordinal); } } }
首先我自己声明了一种类型,继承了IComparable, IComparable<String2>,实现了里面的CompareTo方法;
然后在DataTable中列的类型设定为String2,如此排序就是正常的了。
------------------------------------------------------------------------------------------------------------------------------------------------------------------
以上就是在字符串排序上的遇到的问题和解决方案,不知道有没有更好的解决方案,希望大家指出错误,还是小菜鸟一个。