網站首頁 編程語言 正文
在文件夾中,我們經常有類似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
相關推薦
- 2022-11-27 Windows批處理文件(.bat和.cmd)及區別詳解_DOS/BAT
- 2022-03-23 QT實現定時關閉消息提示框_C 語言
- 2022-09-24 Go?iota關鍵字與枚舉類型實現原理_Golang
- 2022-12-06 Python中八種數據導入方法總結_python
- 2022-03-14 springboot下Static變量通過@Value和set方法注入失敗的問題和解決辦法
- 2021-12-02 C/C++?Qt數據庫SqlRelationalTable關聯表詳解_C 語言
- 2022-09-18 C++如何實現二叉樹鏈表_C 語言
- 2022-11-02 python調用subprocess模塊實現命令行操作控制SVN的方法_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支