繁体   English   中英

使用批处理文件将文件名附加到上次修改的日期和时间

[英]Append to a filename last modified date and time with a batch file

我正在尝试将所有*.csv文件从一个文件夹复制到另一个文件夹,但是在复制时,我需要将文件的修改日期和时间添加到文件名中。 例如,如果文件名是Test.csv并且已在11/21/2018 15:01:10上进行了修改, 15:01:10输出应为Test11-21-201815_01-10.csv 我找到了向其添加当前时间戳的脚本,但是我需要添加文件的修改日期。 您可以在下面看到它:

@echo off
set Source=C:\csvtest
set Target=C:\csvtest\csvtest\Archive
FOR /f "tokens=1-8 delims=/.:- " %%A in ("%date%%time%") DO (
SET Month=%%B
SET Day=%%C
SET Year=%%D
SET Hours=%%E
SET Minutes=%%F
SET Seconds=%%G
SET All=%%B-%%C-%%D_%%E-%%F-%%G
)

FOR %%i IN ("%Source%\*.csv") DO (
COPY "%%i" "%Target%\%%~Ni %All%.csv")

在此先感谢您的帮助。

在SO上有一些附加日期的示例,
但是我将使用PowerShell作为完成此任务的工具(分批包装)。

:: Q:\Test\2018\11\23\SO_53450598.cmd
@echo off
set "Source=C:\test"
set "Target=C:\test\Archive"
PowerShell -Nop -C "Get-ChildItem '%Source%\*.csv'|Copy-Item -Destination {'%Target%\{0} {1:MM-dd-yyyy_HH-mm-ss}.csv' -f $_.BaseName,$_.LastWriteTime} -WhatIf"

如果输出看起来正常,请最后删除-WhatIf

如果未加载PowerShell,@ LotPings方式将持续大量时间。

因此,我将在需要delayedexpansion批处理文件中提供一种更快,更易理解的方法:

@echo off
setlocal enabledelayedexpansion
for /f "tokens=1-2" %%a IN ('forfiles /M file.ext /C "cmd /C echo @fdate @ftime"') do (
 set line1=%%a
 set line2=%%b
 set line1r=!line1:/=-!
 set line2r=!line2::=-!
 rename "file.ext" "file!line1r!!line2r!.ext"
)
rem NOTE: Date format is DD-MM-YYYY. Time format is HH-MM-SS.

让我们分解一下:

for /f ...对于我来说,众所周知。

命令forfiles /M file.ext /C "cmd /C echo @fdate @ftime"表示对/M选项( file.ext )中指定的文件运行命令( /C )。 "cmd /C echo @fdate @ftime"表示打开新的cmd并执行字符串指定的命令,然后终止。 @fdate是文件的最后修改日期,而@ftime是文件的最后修改时间。

我们为@fdate@ftime分别设置变量line1line2 ,然后对其进行一些格式更改。

最后,我们将file.ext重命名为fileDD-MM-YYYYHH-MM-SS.ext

有关更多信息,请输入for /? & forfiles /? for /? & forfiles /? 在一个新鲜的cmd中。

希望这对您有所帮助,因为它更快。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM