首页 > 解决方案 > 使用批处理文件附加到文件名的最后修改日期和时间

问题描述

我正在尝试将所有*.csv文​​件从一个文件夹复制到另一个文件夹,但是在复制时我需要将文件的修改日期和时间添加到文件名。例如,如果文件名是Test.csv并且它在输出上被修改11/21/2018 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")

在此先感谢您的帮助。

标签: batch-filebatch-renamedatemodified

解决方案


这里有一些关于附加日期的示例,
但我会使用 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最后的。


推荐阅读