C#ASP.Net获取文件夹列表,按部分名称排序

时间:2018-10-11 15:38:24

标签: c# asp.net sorting getdirectories

我有一个文件夹,其中包含多个子文件夹,这些子文件夹以此名称命名(2位数字的月份+ 4位数字的年份)。

102018、062014、092018、042016、072017、012016

我需要获取一个文件夹列表才能循环浏览,该列表按名称的年份部分然后按名称的月份部分进行排序。名称格式始终是2位数的月份和4位数的年份。

然后,列表应按以下顺序排序

102018、092018、072017、042016、012016、062014

我可以使用代码获取列表

string[] SubDirs = Directory.GetDirectories(@"c:\MainFolder\");

但是我不知道如何根据需要对文件夹名称进行排序。有人可以帮忙吗?

4 个答案:

答案 0 :(得分:1)

尝试一下

string[] foldernames = Directory.GetDirectories(@"c:\MainFolder\");
List<DateTime> result =  new List<DateTime>();
foreach (var element in foldernames)
{
    result.Add(DateTime.Parse(element.Substring(0,2)+"-"+element.Substring(2)));
}


result.OrderByDescending(d => d).Select(s => new {SortedFile = s.ToShortDateString().Replace(@"/1/","")});

result.OrderByDescending(d => d).Select(s => 
      s.ToShortDateString().Replace(@"/1/",""));

结果将按您需要的顺序包含名称

答案 1 :(得分:1)

对于指定的文件夹名称格式,您可以使用正则表达式,OrderByDescendingThenByDescending方法。例如:

var year = new Regex(@"\d{4}$", RegexOptions.Compiled);
var month = new Regex(@"^\d{2}", RegexOptions.Compiled);
string[] SubDirs = Directory
    .GetDirectories(@"c:\MainFolder\")
    .OrderByDescending(dir => year.Match(dir)?.Value, StringComparer.OrdinalIgnoreCase)
    .ThenByDescending(dir => month.Match(dir)?.Value, StringComparer.OrdinalIgnoreCase)
    .ToArray();

答案 2 :(得分:1)

您可以将日期临时存储为yyyyMM并对其进行排序。

为避免提取日期时出现问题,我确保目录名称以六位数字开头。

using System;
using System.Linq;
using System.IO;
using System.Text.RegularExpressions;

namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            string dirToExamine = @"C:\temp\testDirs";

            /* Get the directories which start with six digits */
            var re = new Regex("^[0-9]{6}");
            var dirs = new DirectoryInfo(dirToExamine).GetDirectories()
                .Where(d => re.IsMatch(d.Name))
                .ToList();

            /* The directory names start MMyyyy but we want them ordered by yyyyMM */
            var withDates = dirs.Select(d => new
            {
                Name = d,
                YearMonth = d.Name.Substring(2, 4) + d.Name.Substring(0, 2)
            })
                .OrderByDescending(f => f.YearMonth, StringComparer.OrdinalIgnoreCase)
                .Select(g => g.Name).ToList();

            Console.WriteLine(string.Join("\r\n", withDates));
            Console.ReadLine();

        }
    }
}

(它可能看起来像很多代码,但我对其进行了格式化以适合此列的宽度。)

我在以下目录名称(以dir /b列出)上对其进行了测试:

012016abcd
042016
062014
0720179876
092018
102018 Some text

并获得所需的订购:

102018 Some text
092018
0720179876
042016
012016abcd
062014

如果您随后想要按该顺序对每个目录中的文件进行操作,则非常简单,因为您可以在DirectoryInfo实例上使用.GetFiles()

foreach(var di in withDates)
{
    FileInfo[] files = di.GetFiles();
    foreach(var fil in files)
    {
        Console.WriteLine(fil.Name);
    }
}

答案 3 :(得分:0)

您可以使用Array.Sort,使用第二个参数来提供delegate函数,该函数会将字符串切成3个部分(年,月,日)并返回正确的顺序。