C# - 如何通过linq对列表字符串编号进行排序?

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解决方案或更好的方法进行排序.

das*_*ght 9

由于日期的格式可以按字典顺序排序,因此您可以使用字符串排序按日期前缀排序,并通过解析整数来解析关系:

var sorted = listStr
    .OrderBy(s => s.Split('_')[0])
    .ThenBy(s => int.Parse(s.Split('_')[1]));
Run Code Online (Sandbox Code Playgroud)

演示.