日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

C#對文件名智能排序的算法_C#教程

作者:天方 ? 更新時間: 2022-08-10 編程語言

在文件夾中,我們經常有類似s_1.txt、s_2.txt、s_10.txt、s_11.txt這樣的命名方式,我們期望的排序方式是s_1.txt、s_2.txt、s_10.txt、s_11.txt(Vista & Windows7是這種方式),然而,按照常規的字符串排序算法的到的結果是s_1.txt、s_10.txt、s_11.txt、s_2.txt(Windows XP是這種方式)。

要實現方式1所需要的智能排序效果,我們的排序算法需要滿足如下規則:

  • 非數字部分按照字符串排序

  • 數字部分按照大小排序

  • 規則1的優先級高于規則2的優先級

這個規則看起來簡單,但是實現起來卻不是那么容易,因為我們的文件名沒有太大的約束,許多文件名時多段式字符串和數字混合在一起的,文件名之間也沒有規律可循。由于今天寫個小程序的時候需要這種功能,我在網上找了一下,沒有什么合適的通用算法,便自己寫了一個(實際上寫了好幾個,這個是最滿意的一個)。

算法的原理很簡單。

  • 將字符串中的數字左側填充0,變成定長的文件名。
    上述文件被命名為s_01.txt、s_02.txt、s_10.txt、s_11.txt

  • 將新文件名按照默認字符串排序算法排序

代碼如下:

static Regex digitRegex = new Regex(@"\d+");
static string[] SmartSort(IEnumerable<string> files)
{
    //這里只傳文件名,以避免不必要的開銷,不同的文件夾的文件沒有智能排序的必要
    var maxLength = files.Max(file => digitRegex.Matches(file).Cast<Match>().Max(num => num.Length));

    var query = from file in files
                let sortFile = digitRegex.Replace(file, m => m.Value.PadLeft(maxLength, '0'))
                orderby sortFile
                select file;

    return query.ToArray();
}

static void Main(string[] args)
{
    var files = Directory.GetFiles(@"R:\22").Select(i=>Path.GetFileName(i));

    Console.WriteLine(string.Join("\r\n", SmartSort(files)));
}

這個算法可用于文件夾或同種類型的文件排序,對于不同的類型的文件的智能排序,還需要在linq查詢的時候加上一個分組的功能,這里就懶得寫了。

這個算法談不上高效(這個算法只用來對一個文件夾下的所有文件排序,實際上也不存在什么效率問題),但卻是我嘗試的幾種算法中最簡單的一個,也是我最滿意的一個,目前沒有發現什么bug,如果誰有更合適的算法,歡迎指教。

原文鏈接:https://www.cnblogs.com/TianFang/archive/2009/12/05/1617769.html

欄目分類
最近更新