编者按:该文件被选为MATLAB Central本周精选
要对字符串/单元格数组的元素进行排序,请使用NATSORT:
使用NATSORTROWS对字符串/单元格数组的行进行排序:
###总结###
对字符串/单元格/结构数组中的文本进行字母数字排序。考虑到任意数字子字符串的值,对字符串进行排序。例如:比较
>> a = {“a2.txt”,“a10.txt”,“a1.txt”};
>>排序(A)
ans =“a1.txt”“a10.txt”“a2.txt”
> > natsortfiles (A)
ans =“a1.txt”“a2.txt”“a10.txt”
默认情况下,NATSORTFILES将所有连续的数字解释为整数,可以使用正则表达式指定数字子串识别:参见NATSORT了解详细信息。
NatsortFile不执行简单的自然顺序排序,而是分别对文件名和文件扩展名进行排序,以确保字典排序,较短的文件名总是在较长的文件名之前进行排序。同样,文件路径在每个文件分隔符处进行拆分,文件层次结构的每一级都单独排序。
###以DIR为例###
P =“C: \ SomeDir \子目录”;
S=目录(完整文件(P,‘* . txt”));
S = natsortfiles(年代);
为k = 1:元素个数(S)
F = fullfile (P, S (k) . name)
结束
###文件依赖###
自然顺序排序由函数NATSORT (File Exchange 34464)提供。NATSORT的所有可选输入都由NATSORTFILES支持。金宝app
###例子###
>>B={'test2.m';“test10-old.m”;“test.m”;'test10.m';'test1.m'};
> >排序(B)错误的号码顺序:
ans =
“test.m”
'test1.m'
“test10-old.m”
'test10.m'
'test2.m'
> > natsortfiles (B)%先短后长:
ans =
“test.m”
'test1.m'
'test2.m'
'test10.m'
“test10-old.m”
%%目录名:
>> c = {“A2-old \ test.m”;'A10\test.m';“A2 \ test.m”;“A1 \ test.m”;“A1-archive.zip”};
> >排序(C)%数字顺序错误,'-'排序在'\'之前:
ans =
“A1-archive.zip”
'A10\test.m'
“A1 \ test.m”
“A2-old \ test.m”
“A2 \ test.m”
> > natsortfiles (C)%先短后长:
ans =
“A1 \ test.m”
“A1-archive.zip”
“A2 \ test.m”
“A2-old \ test.m”
'A10\test.m'
>> d = {“A1 \ B”,“A+/B”,“A / B1”,“= / B ',“\ B0”};
> >排序(D)
ans =“A+/B”“A / B1”“A1 \ B”“= / B '“\ B0”
> > natsortfiles (D)
ans =“\ B0”“A / B1”“A1 \ B”“A+/B”“= / B '
>> f = {“test_new.m”;“test-old.m”;“test.m”};
> >排序(F)%注意'-'排序在'.'之前:
ans =
“test-old.m”
“test.m”
“test_new.m”
> > natsortfiles (F)%先短后长:
ans =
“test.m”
“test-old.m”
“test_new.m”
引用作为
斯蒂芬(2021)。自然秩序文件名排序(//www.tatmou.com/matlabcentral/fileexchange/47434-natural-order-filename-sort),MATLAB中心文件交换.
MATLAB版本兼容性
使用R2010b创建
与任何版本兼容
平台的兼容性
窗户 macOS Linux标签
致谢
启发:一个普通的字母数字字符串排序器,sort_nat:自然顺序排序,GetFullPath,科学前缀的数字,可定制的自然顺序排序,号码的话,自然秩序行排序,单词数量,数字的科学前缀,下一个可用文件名
启发:单词数量,MRI数据的参数化映射脚本,可定制的自然顺序排序,号码的话,自然秩序行排序,交互式正则表达式工具,下一个可用文件名