MyTetra Share
Делитесь знаниями!
Loop files
Время создания: 23.04.2017 11:41
Раздел: AutoHotkey - Файлы - Loop files and folders
Запись: xintrea/mytetra_db_mcold/master/base/1492936896dlkr1goin8/text.html на

Loop, Files, FilePattern [, Mode] ; v1.1.21+ (recommended)


Loop, FilePattern [, IncludeFolders?, Recurse?]


P arameters

Files [v1.1.21+]

The literal word Files (case-insensitive). This cannot be a variable or expression.


The name of a single file or folder, or a wildcard pattern such as C:\Temp\*.tmpFilePattern is assumed to be in %A_WorkingDir%  if an absolute path isn't specified.

Both asterisks and question marks are supported as wildcards. A match occurs when the pattern appears in either the file's long/normal name or its 8.3 short name .

If this parameter is a single file or folder (i.e. no wildcards) and Recurse is set to 1 or Mode includes R, more than one match will be found if the specified file name appears in more than one of the folders being searched.

Mode [v1.1.21+]

Zero or more of the following letters:

D: Include directories (folders).
F: Include files. If both F and D are omitted, files are included but not folders.
R: Recurse into subdirectories (subfolders). If R is omitted, files and folders in subfolders are not included.


One of the following digits, or blank to use the default:
0 (default) Folders are not retrieved (only files).
1 All files and folders that match the wildcard pattern are retrieved.
2 Only folders are retrieved (no files).


One of the following digits, or blank to use the default:
0 (default) Subfolders are not recursed into.
1 Subfolders are recursed into so that files and folders contained therein are retrieved if they match 
FilePattern. All subfolders will be recursed into, not just those whose names match FilePattern.

S pecial Variables Available Inside a File-Loop

The following variables exist within any file-loop. If an inner file-loop is enclosed by an outer file-loop, the innermost loop's file will take precedence:


The name of the file or folder currently retrieved (without the path).


The file's extension (e.g. TXT, DOC, or EXE). The period (.) is not included.


The path and name of the file/folder currently retrieved. If FilePattern contains a relative path rather than an absolute path, the path here will also be relative. In addition, any short (8.3) folder names in FilePattern will still be short (see next item to get the long version).


This is different than A_LoopFileFullPath in the following ways: 1) It always contains the absolute/complete path of the file even if FilePattern contains a relative path; 2) Any short (8.3) folder names in FilePattern itself are converted to their long names; 3) Characters in FilePattern are converted to uppercase or lowercase to match the case stored in the file system. This is useful for converting file names -- such as those passed into a script as command line parameters -- to their exact path names as shown by Explorer.


The 8.3 short path and name of the file/folder currently retrieved. For example: C:\MYDOCU~1\ADDRES~1.txt. If FilePattern contains a relative path rather than an absolute path, the path here will also be relative.

To retrieve the complete 8.3 path and name for a single file or folder, specify its name for FilePattern as in this example:

Loop, C:\My Documents\Address List.txt

ShortPathName = %A_LoopFileShortPath%

Select | Download

NOTE: This variable will be blank if the file does not have a short name, which can happen on systems where NtfsDisable8dot3NameCreation has been set in the registry. It will also be blank if FilePattern contains a relative path and the body of the loop uses SetWorkingDir  to switch away from the working directory in effect for the loop itself.


The 8.3 short name, or alternate name of the file. If the file doesn't have one (due to the long name being shorter than 8.3 or perhaps because short-name generation is disabled on an NTFS file system), A_LoopFileName will be retrieved instead.


The path of the directory in which A_LoopFileName resides. If FilePattern contains a relative path rather than an absolute path, the path here will also be relative. A root directory will not contain a trailing backslash. For example: C:


The time the file was last modified. Format YYYYMMDDHH24MISS .


The time the file was created. Format YYYYMMDDHH24MISS .


The time the file was last accessed. Format YYYYMMDDHH24MISS .


The attributes  of the file currently retrieved.


The size in bytes of the file currently retrieved. Files larger than 4 gigabytes are also supported.


The size in Kbytes of the file currently retrieved, rounded down to the nearest integer.


The size in Mbytes of the file currently retrieved, rounded down to the nearest integer.

R emarks

A file-loop is useful when you want to operate on a collection of files and/or folders, one at a time.

All matching files are retrieved, including hidden files. By contrast, OS features such as the DIR command omit hidden files by default. To avoid processing hidden, system, and/or read-only files, use something like the following inside the loop:

if A_LoopFileAttrib contains H,R,S ; Skip any file that is either H (Hidden), R (Read-only), or S (System). Note: No spaces in "H,R,S".

continue ; Skip this file and move on to the next one.

Select | Download

To retrieve files' relative paths instead of absolute paths during a recursive search, use SetWorkingDir  to change to the base folder prior to the loop, and then omit the path from the Loop (e.g. Loop, *.*, 0, 1). That will cause A_LoopFileFullPath  to contain the file's path relative to the base folder.

A file-loop can disrupt itself if it creates or renames files or folders within its own purview. For example, if it renames files via FileMove  or other means, each such file might be found twice: once as its old name and again as its new name. To work around this, rename the files only after creating a list of them. For example:

FileList =

Loop, Files, *.jpg

FileList = %FileList%%A_LoopFileName%`n

Loop, Parse, FileList, `n

FileMove, %A_LoopField%, renamed_%A_LoopField%

Select | Download

Files in an NTFS file system are probably always retrieved in alphabetical order. Files in other file systems are retrieved in no particular order. To ensure a particular ordering, use the Sort  command as shown in the Examples section below.

Files and folders with a complete path name longer than 259 characters are skipped over as though they do not exist. Such files are rare because normally, the operating system does not allow their creation.

See Loop  for information about Blocks Break Continue , and the A_Index variable (which exists in every type of loop).

R elated

Loop Break Continue Blocks SplitPath FileSetAttrib FileSetTime

E xamples

; Example #1:

Loop Files, %A_ProgramFiles%\*.txt, R ; Recurse into subfolders.


MsgBox, 4, , Filename = %A_LoopFileFullPath%`n`nContinue?

IfMsgBox, No



Select | Download


; Example #2: Calculate the size of a folder, including the files in all its subfolders:

SetBatchLines, -1 ; Make the operation run at maximum speed.

FolderSizeKB = 0

FileSelectFolder, WhichFolder ; Ask the user to pick a folder.

Loop, Files, %WhichFolder%\*.*, R

FolderSizeKB += %A_LoopFileSizeKB%

MsgBox Size of %WhichFolder% is %FolderSizeKB% KB.

Select | Download


; Example #3: Retrieve file names sorted by name (see next example to sort by date):

FileList = ; Initialize to be blank.

Loop, C:\*.*

FileList = %FileList%%A_LoopFileName%`n

Sort, FileList, R ; The R option sorts in reverse order. See Sort for other options.

Loop, parse, FileList, `n


if A_LoopField = ; Ignore the blank item at the end of the list.


MsgBox, 4,, File number %A_Index% is %A_LoopField%. Continue?

IfMsgBox, No



Select | Download


; Example #4: Retrieve file names sorted by modification date:

FileList =

Loop, Files, %A_MyDocuments%\Photos\*.*, FD ; Include Files and Directories

FileList = %FileList%%A_LoopFileTimeModified%`t%A_LoopFileName%`n

Sort, FileList ; Sort by date.

Loop, Parse, FileList, `n


if A_LoopField = ; Omit the last linefeed (blank item) at the end of the list.


StringSplit, FileItem, A_LoopField, %A_Tab% ; Split into two parts at the tab char.

MsgBox, 4,, The next file (modified at %FileItem1%) is:`n%FileItem2%`n`nContinue?

IfMsgBox, No



Select | Download


; Example #5: Copy only the source files that are newer than their counterparts

; in the destination:


; Caller has set the variables CopySourcePattern and CopyDest for us.

Loop, Files, %CopySourcePattern%


copy_it = n

IfNotExist, %CopyDest%\%A_LoopFileName% ; Always copy if target file doesn't yet exist.

copy_it = y



FileGetTime, time, %CopyDest%\%A_LoopFileName%

EnvSub, time, %A_LoopFileTimeModified%, seconds ; Subtract the source file's time from the destination's.

if time < 0 ; Source file is newer than destination file.

copy_it = y


if copy_it = y


FileCopy, %A_LoopFileFullPath%, %CopyDest%\%A_LoopFileName%, 1 ; Copy with overwrite=yes

if ErrorLevel

MsgBox, Could not copy "%A_LoopFileFullPath%" to "%CopyDest%\%A_LoopFileName%".




Select | Download


; Example #6: Convert filenames passed in via command-line parameters to long names,

; complete path, and correct uppercase/lowercase characters as stored in the file system.

Loop %0% ; For each file dropped onto the script (or passed as a parameter).


GivenPath := %A_Index% ; Retrieve the next command line parameter.

Loop %GivenPath%, 1

LongPath = %A_LoopFileLongPath%

MsgBox The case-corrected long path name of file`n%GivenPath%`nis:`n%LongPath%


Так же в этом разделе:
MyTetra Share v.0.58
Яндекс индекс цитирования