Oos*_*uke 1 c# linq sorting string
我有一个列表,列表中的每个元素都是一个字符串,其中包含特定格式的日期和整数:yyyyMMdd_number.
List<string> listStr = new List<string> { "20170822_10", "20170821_1", "20170823_4", "20170821_10", "20170822_11", "20170822_5",
"20170822_2", "20170821_3", "20170823_6", "20170823_21", "20170823_20", "20170823_2"};
Run Code Online (Sandbox Code Playgroud)
使用方法时 listStr.Sort();
结果如下:
20170821_1 20170821_10 20170821_3 20170822_10 20170822_11 20170822_2 20170822_5 20170823_2 20170823_20 20170823_21 20170823_4 20170823_6
预期产出:
20170821_1 20170821_3 20170821_10 20170822_2 20170822_5 20170822_10 20170822_11 20170823_2 20170823_4 20170823_6 20170823_20 20170823_21
方式:我认为每个字符串(day_number)将用下划线分割,然后按数字进行比较和排序.但在这种情况下,请建议我使用LINQ解决方案或更好的方法进行排序.
由于日期的格式可以按字典顺序排序,因此您可以使用字符串排序按日期前缀排序,并通过解析整数来解析关系:
var sorted = listStr
.OrderBy(s => s.Split('_')[0])
.ThenBy(s => int.Parse(s.Split('_')[1]));
Run Code Online (Sandbox Code Playgroud)