背景描述:项目中有一个List<Bolt> AResultSQLList
其中A.ANum的格式为“A-1”,“B-1”,“A-2”,“A-3”,“C-1”等任意排列组合
需求:现在想对List<A>进行排序:按照A-B-C为首要条件,数字为第二条件。
结果示意:A-1,A-2,A-3,B-1,C-1
public class A
{
private string _ANum = "1";
///要进行排序的字段
public string ANum
{
get { return _ANum; }
set
{
_ANum = value;
OnPropertyChanged("ANum");//这里是实现WPF界面绑定通知用的,可以不看
}
}
}
我使用的方法是Sort
AResultSQLList.Sort((l, r) =>
{
if (l.ANum.Split('-')[0] == r.ANum.Split('-')[0])
{
return int.Parse(l.ANum.Split('-')[1])
.CompareTo(int.Parse(r.ANum.Split('-')[1]));//字母相同按照数字排序
}
else
{
return string.Compare(l.ANum.Split('-')[0], r.ANum.Split('-')[0]);//字母不同按照字母排序
}
} );
不知道有没有大佬有更加简单,简洁的方法实现这个功能呢。