2

我想用 DIR 按它们的时间戳对以下文件进行排序,该时间戳在文件名中定义 - 最早的在前:Timestamp = YYYYDDMM

NAME_20121410.dat
NAME_20121509.dat
NAME_20121609.dat

结果应如下所示:

NAME_20121509.dat
NAME_20121609.dat
NAME_20121410.dat

我如何通过单线实现这一目标?

4

2 回答 2

3

由于日期格式很愚蠢,您需要先拆分文件名并对重新排列的名称进行排序。
不是一个衬里,但它可以工作(在批处理文件中)。

@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
)
于 2012-09-19T13:38:36.450 回答
2

如果你可以使用 PowerShell,试试这个:

PS II> ls *.dat | sort {$_ -replace '(\d{2})(\d{2})\.*','$2$1'}
于 2012-09-19T18:11:50.177 回答