欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2022年06月17日 14:15:00   作者:天方  
這篇文章介紹了C#對文件名智能排序的算法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

在文件夾中,我們經(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是這種方式)。

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

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

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

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

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

算法的原理很簡單。

  • 將字符串中的數(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查詢的時候加上一個分組的功能,這里就懶得寫了。

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

到此這篇關(guān)于C#對文件名排序的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C#中泛型類和擴(kuò)展方法如何使用

    C#中泛型類和擴(kuò)展方法如何使用

    這篇文章介紹了C#中泛型類和擴(kuò)展方法的用法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • C#實現(xiàn)異步連接Sql Server數(shù)據(jù)庫的方法

    C#實現(xiàn)異步連接Sql Server數(shù)據(jù)庫的方法

    這篇文章主要介紹了C#實現(xiàn)異步連接Sql Server數(shù)據(jù)庫的方法,涉及C#中await方法的相關(guān)使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-04-04
  • C# PropertyInfo類案例詳解

    C# PropertyInfo類案例詳解

    這篇文章主要介紹了C# PropertyInfo類案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 關(guān)于c#中單例模式的一些問題

    關(guān)于c#中單例模式的一些問題

    這篇文章主要給大家介紹了關(guān)于c#中單例模式的一些問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • C#數(shù)據(jù)類型實現(xiàn)背包、隊列和棧

    C#數(shù)據(jù)類型實現(xiàn)背包、隊列和棧

    本文詳細(xì)講解了C#數(shù)據(jù)結(jié)構(gòu)類型,并實現(xiàn)背包、隊列和棧的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • C#讀取文件所有行到數(shù)組的方法

    C#讀取文件所有行到數(shù)組的方法

    這篇文章主要介紹了C#讀取文件所有行到數(shù)組的方法,涉及C#針對文件及數(shù)組的相關(guān)操作技巧,需要的朋友可以參考下
    2015-07-07
  • C#常用的字符串?dāng)U展方法匯總

    C#常用的字符串?dāng)U展方法匯總

    這篇文章主要介紹了C#常用的字符串?dāng)U展方法匯總,包括了常見的字符串操作與數(shù)據(jù)類型轉(zhuǎn)換等,非常具有實用價值,需要的朋友可以參考下
    2014-10-10
  • C#為控件添加自定義事件及自定義觸發(fā)

    C#為控件添加自定義事件及自定義觸發(fā)

    C#本身提供了很強(qiáng)大的控件庫,但是很多控件庫的功能只是一些基本的功能,本文主要介紹了C#為控件添加自定義事件及自定義觸發(fā),具有一定的參考價值,感興趣的可以了解一下
    2022-04-04
  • C# 計算標(biāo)準(zhǔn)偏差相當(dāng)于Excel中的STDEV函數(shù)實例

    C# 計算標(biāo)準(zhǔn)偏差相當(dāng)于Excel中的STDEV函數(shù)實例

    下面小編就為大家?guī)硪黄狢# 計算標(biāo)準(zhǔn)偏差相當(dāng)于Excel中的STDEV函數(shù)實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • 詳解WPF如何動態(tài)生成DataGrid的行和列

    詳解WPF如何動態(tài)生成DataGrid的行和列

    在日常開發(fā)中,DataGrid作為二維表格,非常適合數(shù)據(jù)的展示和統(tǒng)計,本文以一些簡單的小例子,簡述在WPF開發(fā)中,如何動態(tài)生成DataGrid的行和列,需要的可以了解下
    2024-02-02

最新評論