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

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

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

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

在文件夾中,我們經(jīng)常有類似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是這種方式),然而,按照常規(guī)的字符串排序算法的到的結(jié)果是s_1.txt、s_10.txt、s_11.txt、s_2.txt(Windows XP是這種方式)。

要實(shí)現(xiàn)方式1所需要的智能排序效果,我們的排序算法需要滿足如下規(guī)則:

  • 非數(shù)字部分按照字符串排序

  • 數(shù)字部分按照大小排序

  • 規(guī)則1的優(yōu)先級高于規(guī)則2的優(yōu)先級

這個規(guī)則看起來簡單,但是實(shí)現(xiàn)起來卻不是那么容易,因?yàn)槲覀兊奈募麤]有太大的約束,許多文件名時多段式字符串和數(shù)字混合在一起的,文件名之間也沒有規(guī)律可循。由于今天寫個小程序的時候需要這種功能,我在網(wǎng)上找了一下,沒有什么合適的通用算法,便自己寫了一個(實(shí)際上寫了好幾個,這個是最滿意的一個)。

算法的原理很簡單。

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

  • 將新文件名按照默認(rèn)字符串排序算法排序

代碼如下:

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查詢的時候加上一個分組的功能,這里就懶得寫了。

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

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

欄目分類
最近更新