我一直在尋找一個解決方案,這一段時間了。用於自然分類的IComparer
當我整理了以下使用字符串排序我的列表:
10
10b
1111
1164
1174
23
23A
23B
23D
23E
我真正想要的清單是:
10
10b
23
23A
23B
23D
23E
1111
1164
1174
數值排序不要麼做的工作。
我一直在尋找一個解決方案,這一段時間了。用於自然分類的IComparer
當我整理了以下使用字符串排序我的列表:
10
10b
1111
1164
1174
23
23A
23B
23D
23E
我真正想要的清單是:
10
10b
23
23A
23B
23D
23E
1111
1164
1174
數值排序不要麼做的工作。
最簡單的是包裝的Win32 API調用,如https://stackoverflow.com/a/248613/631687
解釋的。如果你有LINQ,你可以使用OrderBy
:
Regex digitPart = new Regex(@"^\d+", RegexOptions.Compiled);
...
myList.OrderBy(x => int.Parse(digitPart.Match(x).Value))
我希望這個鏈接將幫助您使用natural Sort Comparer自然排序
using System;
using System.Collections.Generic;
using System.Text.RegularExpressions;
public class NumStrCmp : IComparer<string> {
public int Compare(string x, string y){
Regex regex = new Regex(@"(?<NumPart>\d+)(?<StrPart>\D*)",RegexOptions.Compiled);
var mx = regex.Match(x);
var my = regex.Match(y);
var ret = int.Parse(mx.Groups["NumPart"].Value).CompareTo(int.Parse(my.Groups["NumPart"].Value));
if(ret != 0) return ret;
return mx.Groups["StrPart"].Value.CompareTo(my.Groups["StrPart"].Value);
}
}
class Sample {
static public void Main(){
var data = new List<string>() {"10","10b","1111","1164","1174","23","23A","23B","23D","23E"};
data.Sort(new NumStrCmp());
foreach(var x in data){
Console.WriteLine(x);
}
}
}
爲什麼數字排序不能完成這項工作? – lahsrah 2011-12-19 23:03:30
看看http://www.codeproject.com/KB/string/NaturalSortComparer.aspx – 2011-12-19 23:08:09
@pratapchandra - 應該只是讓你的評論一個正式的答案。 – Jagd 2011-12-19 23:16:51