find
is a command-line utility that locates files based on some user-specified criteria and either prints the pathname of each matched object or, if another action is requested, performs that action on each matched object.
It initiates a search from a desired starting location and then recursively traverses the nodes (directories) of a hierarchical structure (typically a find
returns a list of all files below the current locate
programs use a database of indexed files obtained through find
(updated at regular intervals, typically by cron
The cron command-line utility is a job scheduler on Unix-like operating systems. Users who set up and maintain software environments use cron to schedule jobs (commands or shell scripts), also known as cron jobs, to run periodically at fixed t ...
job) to provide a faster method of searching the entire file system for files by name.
History
find
appeared in Version 5 Unix as part of the Programmer's Workbench project, and was written by Dick Haight alongside find
implementation was originally written by Eric Decker. It was later enhanced by David MacKenzie, Jay Plett, and Tim Wood.
The command has also been ported to the Find syntax
find
command should treat symbolic links. The default behaviour is never to follow symbolic links. The flag will cause the find
command to follow symbolic links. The flag will only follow symbolic links while processing the command line arguments. These flags are specified in the POSIX standard for find
. A common extension is the flag, for explicitly disabling symlink following.
At least one path must precede the expression. find
is capable of interpreting wildcards internally and commands must be quoted carefully in order to control shell globbing.
Expression elements are separated by the find
has a large number of additional features not specified by POSIX.
Predicates
Commonly-used primaries include: *-name ''pattern''
: tests whether the file name matches the shell-glob pattern given.
* -type ''type''
: tests whether the file is a given type. b
: block device (buffered);
** c
: character device (unbuffered);
** d
: '' directory'';
** f
: '' regular file'';
** l
: p
: named pipe;
** s
: D
: -print
: always returns true; prints the name of the current file plus a newline to the stdout.
* -print0
: always returns true; prints the name of the current file plus a null character to the stdout. Not required by POSIX.
* -exec ''program'' '' rguments...' ;
: runs ''program'' with the given arguments, and returns true if its exit status was 0, false otherwise. If ''program'', or an argument is , it will be replace by the current path (if ''program'' is , find
will try to run the current path as an executable). POSIX doesn't specify what should happen if multiple are specified. Most implementations will replace all with the current path, but that is not standard behavior.
* -exec ''program'' '' rguments...' +
: always returns true; run ''program'' with the given arguments, followed by as many paths as possible (multiple commands will be run if the maximum command-line size is exceeded, like for xargs).
* -ok ''program'' '' rguments...' ;
: for every path, prompts the user for confirmation; if the user confirms (typically by entering ''y'' or ''yes''), it behaves like -exec ''program rguments...' ;
, otherwise the command is not run for the current path, and false is returned.
* -maxdepth
: Can be used to limit the directory depth to search through. For example, -maxdepth 1
limits search to the current directory.
If the expression uses none of -print0
, -print
, -exec
, or -ok
, find defaults to performing -print
if the conditions test as true.
Operators
Operators can be used to enhance the expressions of the find command. Operators are listed in order of decreasing precedence: *( expr )
: forces precedence;
* ! expr
: true if is false;
* expr1 expr2
(or expr1 -a expr2
): AND. is not evaluated if is false;
* expr1 -o expr2
: OR. is not evaluated if is true.
!
so that it's not interpreted by the shell as the history substitution character.
POSIX protection from infinite output
Real-world file systems often contain looped structures created through the use of hard or soft links. The POSIX standard requires thatExamples
From the current working directory
Regular files only
Commands
The previous examples created listings of results because, by default,find
executes the -print
action. (Note that early versions of the find
command had no default action at all; therefore the resulting list of files would be discarded, to the bewilderment of users.)
Search all directories
find
. More complex filenames including characters special to the shell may need to be enclosed in single quotes.
Search all but one subdirectory tree
-prune
action, for a regular file whose name is ''myfile''.
Specify a directory
Search several directories
Ignore errors
If you're doing this as a user other than root, you might want to ignore permission denied (and any other) errors. Since errors are printed to stderr, they can be suppressed by redirecting the output to /dev/null. The following example shows how to do this in the bash shell:find
command to get around this:
Find any one of differently named files
-ls
operator prints extended information, and the example finds any regular file whose name ends with either 'jsp' or 'java'. Note that the parentheses are required. In many shells the parentheses must be escaped with a backslash (\(
and \)
) to prevent them from being interpreted as special shell characters. The -ls
operator is not available on all versions of find
.
Execute an action
-exec chmod
is a shell command for changing access permissions and special mode flags of files (including special files such as directories). The name is short for ''change mode'' where ''mode'' refers to the permissions and flags collectively.
The co ...
644 \;
in the command. For every regular file whose name ends in .mp3
, the command chmod 644
is executed replacing
with the name of the file. The semicolon (backslashed to avoid the shell interpreting it as a command separator) indicates the end of the command. Permission 644
, usually shown as rw-r--r--
, gives the file owner full permission to read and write the file, while other users have read-only access. In some shells, the
must be quoted. The trailing "" is customarily quoted with a leading "", but could just as effectively be enclosed in single quotes.
Note that the command itself should not be quoted; otherwise you get error messages like
find
is trying to run a file called '' and failing.
If you will be executing over many results, it is more efficient to use a variant of the exec primary that collects filenames up to and then executes COMMAND with a list of filenames.
Delete files and directories
The-delete
action is a GNU extension, and using it turns on -depth
. So, if you are testing a find command with -print
instead of -delete
in order to figure out what will happen before going for it, you need to use -depth -print
.
Delete empty files and print the names (note that -empty
is a vendor unique extension from GNU find
that may not be available in all find
implementations):
-delete
action should be used with conditions such as -empty
or -name
:
Search for a string
This command will search all files from the /tmp directory tree for a string:/dev/null
In some operating systems, the null device is a device file that discards all data written to it but reports that the write operation succeeded. This device is called /dev/null on Unix and Unix-like systems, NUL: (see TOPS-20) or NUL on CP/M a ...
argument is used to show the name of the file before the text that is found. Without it, only the text found is printed. (Alternatively, some versions of grep support a flag that forces the file name to be printed.)
GNU grep
can be used on its own to perform this task:
Search for all files owned by a user
Search in case insensitive mode
Note that-iname
is not in the standard and may not be supported by all implementations.
-iname
switch is not supported on your system then workaround techniques may be possible such as:
Search files by size
Searching files whose size is between 100 kilobytes and 500 kilobytes:Search files by name and size
Searching files by time
Date ranges can be used to, for example, list files changed since a backup. * : modification time * : inode change time * : access time Files modified a relative number of days ago: * +-daystart
to measure time from the beginning of a day (0 o'clock) rather than the last 24 hours.
Example to find all text files in the document folder modified since a week (meaning 7 days):
-newermt YYYY-MM-DD
: Last modified after date
* -not -newermt YYYY-MM-DD
: Last modified before date
Example to find all text files last edited in February 2017:
-newer ile/code>: More recently modified than specified file.
** -cnewer
: Same with inode change time.
** -anewer
: Same with access time.
** Also prependable with -not
for inverse results or range.
List all text files edited more recently than "document.txt":
$ find ~/Documents/ -iname "*.txt" -newer document.txt
Related utilities
* locate
is a Unix search tool that searches a prebuilt database of files instead of directory trees of a file system. This is faster than find
but less accurate because the database may not be up-to-date.
* grep
grep is a command-line utility for searching plaintext datasets for lines that match a regular expression. Its name comes from the ed command g/re/p (global regular expression search and print), which has the same effect. grep was originally de ...
is a command-line utility for searching plain-text data sets for lines matching a regular expression and by default reporting matching lines on standard output Standard may refer to:
Symbols
* Colours, standards and guidons, kinds of military signs
* Standard (emblem), a type of a large symbol or emblem used for identification
Norms, conventions or requirements
* Standard (metrology), an object t ...
.
* tree
In botany, a tree is a perennial plant with an elongated stem, or trunk, usually supporting branches and leaves. In some usages, the definition of a tree may be narrower, e.g., including only woody plants with secondary growth, only ...
is a command-line utility that recursively lists files found in a directory tree, indenting the filenames according to their position in the file hierarchy.
* GNU Find Utilities (also known as findutils) is a GNU package which contains implementations of the tools find
and xargs
.
* BusyBox
BusyBox is a software suite that provides several List of Unix commands, Unix utilities in a single executable file. It runs in a variety of POSIX environments such as Linux, Android (operating system), Android, and FreeBSD, although many of the ...
is a utility that provides several stripped-down Unix tools in a single executable file, intended for embedded operating systems with very limited resources. It also provides a version of find
.
* dir
has the /s option that recursively searches for files or directories.
* Plan 9 from Bell Labs
Plan 9 from Bell Labs is a distributed operating system which originated from the Computing Science Research Center (CSRC) at Bell Labs in the mid-1980s and built on UNIX concepts first developed there in the late 1960s. Since 2000, Plan 9 has ...
uses two utilities to replace : a that only walks the tree and prints the names and a that only filters (like grep) by evaluating expressions in the form of a shell script. Arbitrary filters can be used via pipes. The commands are not part of Plan 9 from User Space
Plan 9 from User Space (also plan9port or p9p) is a Porting, port of many Plan 9 from Bell Labs libraries and applications to Unix-like operating systems. Currently it has been tested on a variety of operating systems, including Linux, macOS, Fr ...
, so Google's Benjamin Barenblat has a ported version to POSIX systems available through GitHub.
* is a simple alternative to written in the Rust programming language
Rust is a general-purpose programming language emphasizing performance, type safety, and concurrency. It enforces memory safety, meaning that all references point to valid memory. It does so without a conventional garbage collector; instea ...
.
See also
* mdfind, a similar utility that utilizes metadata for macOS
macOS, previously OS X and originally Mac OS X, is a Unix, Unix-based operating system developed and marketed by Apple Inc., Apple since 2001. It is the current operating system for Apple's Mac (computer), Mac computers. With ...
and Darwin
* List of Unix commands
This is a list of the shell commands of the most recent version of the Portable Operating System Interface (POSIX) IEEE Std 1003.1-2024 which is part of the Single UNIX Specification (SUS). These commands are implemented in many shells on moder ...
* List of DOS commands
* Filter (higher-order function)
In functional programming, filter is a higher-order function that processes a data structure (usually a list (data structure), list) in some order to produce a new data structure containing exactly those elements of the original data structure for ...
* find (Windows), a DOS and Windows command that is very different from Unix find
* forfiles, a Windows command that finds files by attribute, similar to Unix find
* grep
grep is a command-line utility for searching plaintext datasets for lines that match a regular expression. Its name comes from the ed command g/re/p (global regular expression search and print), which has the same effect. grep was originally de ...
, a Unix command that finds text matching a pattern, similar to Windows find
References
External links
Official webpage for GNU find
Command find – 25 practical examples
{{Unix commands
Information retrieval systems
Standard Unix programs
Unix SUS2008 utilities
Plan 9 commands
IBM i Qshell commands