改变一个或多个文件或文件夹的时间戳。支持通配符。
FileSetTime [, YYYYMMDDHH24MISS, FilePattern, WhichTime, OperateOnFolders?, Recurse?]
如果为空或省略, 则它默认为当前时间. 否则, 指定操作使用的时间 (请参阅备注了解时间的格式). 不支持 1601 以前的年份.
此参数可以为 表达式. 因此, 如果需要连接多个变量来形成单个时间戳, 则应该使用 点运算符 代替百分号. 例如:FileSetTime, Year . Month . Day, C:\My File.txt
。
单个文件或文件夹的名称或者通配符模式, 例如 C:\Temp\*.tmp. 如果未指定绝对路径则假定 FilePattern 在 %A_WorkingDir% 中.
如果省略, 则使用最内层 文件循环 的当前文件.
0 (默认) 不对文件夹进行操作 (仅文件).
1对匹配通配符模式的所有文件和文件夹进行操作.
2仅对文件夹进行操作 (不操作文件).
注: 如果 FilePattern 是单个文件夹而不是通配符模式, 那么总是忽略此设置.
此参数可以为 表达式.
0 (默认) 不对子文件夹进行递归.
1递归子文件夹, 以便对包含在其中的匹配 FilePattern 的所有文件和文件夹进行操作. 将递归所有子文件夹, 而不仅是名称匹配 FilePattern 的那些. 但是, 文件和文件夹的完整路径和名称超过 259 个字符时, 这些文件和文件夹会被跳过, 就像它们不存在一样. 这样的文件很罕见, 因为操作系统一般不允许创建它们.
此参数可以为 表达式.
[v1.1.04+] 此命令失败时会抛出异常. 想了解更多信息, 请参阅 运行时错误.
ErrorLevel 被设置为改变属性 失败 的文件数, 否则为 0. 如果指定的时间戳无效或 FilePattern 解析结果为空值, 则 ErrorLevel 被置为 1.
如果找到了文件, 则 A_LastError 会被设置为 0 (零) 或最近一次操作失败时调用操作系统 GetLastError() 函数的结果. 否则 A_LastError 包含了没有找到文件原因的错误码.
在 FAT16 & FAT32 卷上的文件上次访问时间可能不如在 NTFS 卷上那么精确.
YYYYMMDDHH24MISS 格式中元素表示的含义分别为:
YYYY | 4 位数的年份 |
MM | 2 位数的月份 (01-12) |
DD | 月的 2 位数的天数 (01-31) |
HH24 | 24 小时格式的 2 位小时数 (00-23). 例如, 09 是 9am 而 21 是 9pm. |
MI | 2 位数的分钟数 (00-59) |
SS | 2 位数的秒数 (00-59) |
如果只给出了 YYYYMMDDHH24MISS 中的部分字符串 (例如 200403), 则任何省略的元素将使用下面的默认值:
MM: 月份 01
DD: 日期 01
HH24: 小时 00
MI: 分钟 00
SS: 秒 00
内置变量 A_Now 包含了上述格式的当前本地时间. 同样地, A_NowUTC 包含了当前的协调世界时.
注: 使用 EnvAdd 和 EnvSub 可以对日期时间值进行比较和加减. 此外, 最后不要使用大于或小于来比较时间, 除非它们的字符串长度相同. 这是因为此时它们被视为数字进行比较; 例如, 20040201 数值上总是小于 (但时间顺序上较后) 200401010533. 所以应该使用 EnvSub 来计算出它们之间的时间差是正数还是负数.
FileGetTime, FileGetAttrib, FileSetAttrib, FileGetSize, FileGetVersion, FormatTime, 文件循环, EnvAdd, EnvSub
; 设置所有匹配文件的修改时间为当前时间: FileSetTime, , C:\temp\*.txt ; 设置修改日期 (时间将为午夜): FileSetTime, 20040122, C:\My Documents\test.doc ; 设置创建日期. 把时间设置为 4:55pm: FileSetTime, 200401221655, C:\My Documents\test.doc, C ; 改变匹配一种模式的所有文件的修改时间. ; 由于最后一个参数的作用, 所以也会改变所有匹配的文件夹.: FileSetTime, 20040122165500, C:\Temp\*.*, M, 1