我想用 DIR 按它们的时间戳对以下文件进行排序,该时间戳在文件名中定义 - 最早的在前:Timestamp = YYYYDDMM
NAME_20121410.dat
NAME_20121509.dat
NAME_20121609.dat
结果应如下所示:
NAME_20121509.dat
NAME_20121609.dat
NAME_20121410.dat
我如何通过单线实现这一目标?
我想用 DIR 按它们的时间戳对以下文件进行排序,该时间戳在文件名中定义 - 最早的在前:Timestamp = YYYYDDMM
NAME_20121410.dat
NAME_20121509.dat
NAME_20121609.dat
结果应如下所示:
NAME_20121509.dat
NAME_20121609.dat
NAME_20121410.dat
我如何通过单线实现这一目标?
由于日期格式很愚蠢,您需要先拆分文件名并对重新排列的名称进行排序。
不是一个衬里,但它可以工作(在批处理文件中)。
@echo off
(
for %%A in (*_*.dat) do @(
call set "name=%%A"
call set "nameDate=%%name:*_=%%"
call set "Year=%%nameDate:~0,4%%"
call set "Day=%%nameDate:~4,2%%"
call set "Month=%%nameDate:~6,2%%"
call echo %%Year%%%%Month%%%%Day%% %%name%%
)
) | sort | (
for /F "tokens=1,* delims= " %%A in ('more') DO @echo %%B
)
如果你可以使用 PowerShell,试试这个:
PS II> ls *.dat | sort {$_ -replace '(\d{2})(\d{2})\.*','$2$1'}