find(1)
find --
find files
Synopsis
find [path-list] [predicate-list]
Description
find
recursively descends the directory hierarchy for
each pathname in the
path-list
(that is, one or more pathnames)
seeking files that match a predicate-list,
a boolean expression
written in the primaries given below.
The default path-list is ``.'' (the current directory).
find processes supplementary code set characters,
and recognizes supplementary code set characters
in path-list and as described below,
according to the locale specified in the LC_CTYPE
environment variable (see LANG on
environ(5)).
find performs pattern searches
on characters, not bytes.
In the descriptions, the argument
n
is used as a decimal integer
where
+n
means more than
n,
-n
means less than
n
and
n
means exactly
n.
Valid expressions in the predicate-list are:
- -exit
-
Always true; causes find to exit immediately
with the current exit value. This can be used to preempt
the default -print expression.
- -name pattern
-
True if
pattern
matches the current filename.
Normal shell
filename generation characters
(see
sh(1))
may be used.
A backslash (\) is used as an escape character within the pattern.
The pattern should be escaped or quoted when
find
is invoked from the shell.
pattern may contain supplementary code set characters.
Note: a slash (/) can be used in pattern, but it will not match
any particular filename.
- -perm [-]onum
-
True if the file permission flags
exactly
match the
octal number
onum
(see
chmod(1)).
If
onum
is prefixed by a minus sign (-),
only the bits that are set in
onum
are compared with the file permission flags,
and the expression evaluates true if they match.
- -perm [-]mode
-
The mode argument is used to represent file mode bits. Its format is identical
to the chmod symbolic_mode operand and is interpreted in the following manner.
A template is assumed, with all file mode bits cleared. An op symbol of + sets the
appropriate mode bits in the template; - clears the appropriate bits; and
= sets the appropriate mode bits, without regard to the contents of
the process's file mode creation mask. The op symbol of - can't be the first character of mode.
If the hyphen is omitted, the primary evaluates as true when
the file permission bits match
the value of the resulting template exactly. Otherwise, if mode has a hyphen
prefix, the primary evaluates as true if at least all the bits in the
resulting template are set in the file permission bits.
- -size n[c]
-
True if the file is
n
blocks long (512 bytes per block).
If
n
is followed by a
c,
the size is in bytes.
- -atime n
-
True if the file access time subtracted from the initialization time is
n-1 to n multiples of 24 hours. The initialization time is
the time between the invocation of the find utility and the first
access by that invocation to any file file specified by its path operands.
- -mtime n
-
True if the file modification time subtracted from the initialization
time is n-1 to n multiples of 24 hours. The initialization time is
the time between the invocation of the find utility and the first
access by that invocation to any file file specified by its path operands.
- -ctime n
-
True if the time of last change of file status information subtracted
from the initialization time is n-1 to n multiples of 24 hours.
The initialization time is
the time between the invocation of the find utility and the first
access by that invocation to any file file specified by its path operands.
- -exec cmd
-
True if the executed
cmd
returns
a zero value as exit status.
A command argument
{}
is replaced by the
current pathname.
The end of
cmd
must be punctuated by an escaped
semicolon or a plus sign (+).
When a plus sign is used, cmd
aggregates a set of pathnames and executes
on the set;
when a semicolon is used, cmd executes on one
pathname at a time.
The reason for preferring + to a semicolon is vastly improved performance.
cmd may contain supplementary code set characters.
You can prepend the cmd with tfadmin if you need
to pass privileges to the cmd. This assumes that an entry for you in
the tfadmin database has been previously defined.
The super-user will
execute the cmd with all privileges; prepending the
tfadmin is not necessary in this case.
- -ok cmd
-
Like
-exec
except that the generated command line is printed
with a question mark first.
This is a prompt for confirmation.
It is executed if the response is affirmative. The form of the affirmative response
is locale dependent: ``y'' in the C locale. (See LANG on
environ(5).))
cmd may contain supplementary code set characters.
- -print
-
Always true;
causes the current pathname to be printed.
- -newer file
-
True if
the current file has been modified more recently than the argument
file.
- -depth
-
Always true;
causes descent of the directory hierarchy to be done
so that all entries in a directory are
acted on
before the directory itself.
This can be useful when
find
is used with
cpio(1)
to transfer files
that are contained in directories without
write permission.
- -mount
-
Always true;
restricts the search to the file system containing the directory specified.
- -local
-
True if the file physically resides on the local system.
This does not restrict the search to only files which physically
reside on the local system, it merely matches such files.
See ``Examples''.
- -xdev [argument list]
-
True if you restrict your search to the root file system. If you do not
specify argument list, the search will be made for every file
on local and remote networks.
- ( expression )
-
True if the parenthesized expression is true.
- -type type
-
True if the file type corresponds to the specified type:
- b
-
block special file
- c
-
character special file
- d
-
directory
- f
-
regular file
- l
-
symbolic link
- p
-
fifo (named pipe)
- s
-
socket file
- -follow
-
Causes symbolic links to be followed.
When following symbolic links, find keeps track
of the directories visited so that it can detect infinite
loops; for example, such a loop would occur if a symbolic link pointed
to an ancestor.
This expression should not be used with the -type l expression.
- -links n
-
True if the file has
n
links.
- -user uname
-
True if the file belongs to the user
uname.
If
uname
is numeric and does not appear as a login name in the
/etc/passwd
file, it is taken as a user ID.
- -nouser
-
True if the file belongs to a user not in the
/etc/passwd
file.
- -group gname
-
True if the file belongs to the group
gname.
If
gname
is numeric and does not appear in the
/etc/group
file, it is taken as a group ID.
- -nogroup
-
True if the file belongs to a group not in the
/etc/group
file.
- -fstype type
-
True if the file system to which the file belongs is of type
type.
- -inum n
-
True if the file has inode number
n.
- -prune
-
Always yields true.
Do not examine any directories or files
in the directory structure below the expression
just matched.
See ``Examples''.
The primaries may be combined using the following operators
(in order of decreasing precedence):
- 1.
-
The negation of a primary
(``!''
is the unary
not
operator).
- 2.
-
Concatenation of primaries
(the
and
operation
is implied by the juxtaposition of two primaries).
- 3.
-
Alternation of primaries
(-o is the
or
operator).
Note that when you use find in conjunction with cpio,
if you use the -L option with cpio
then you must use the -follow
expression with find and vice versa.
Otherwise there will be undesirable results.
If no predicate-list is present,
-print is used as the expression.
Otherwise, if the given expression does not contain any of the primaries
-exec, -ok, or -print,
the given expression can be replaced by
(given_expression) -print.
The -user, -group, and -newer primaries each evaluate
their respective arguments once.
Files
- /etc/passwd
-
- /etc/group
-
- /usr/lib/locale/locale/LC_MESSAGES/uxcore.abi
-
language-specific message file (See LANG on
environ(5).)
Examples
Remove all files in your home directory
named a.out or .o that
have not been accessed for a week:
find $HOME \( -name a.out -o -name '.o' \) -atime +7 -exec rm {} \;
Recursively print all filenames in the current directory and below,
but skipping
SCCS
directories:
find . -name SCCS -prune -o -print
Recursively print all filenames in the current directory and below,
skipping the contents of
SCCS
directories, but printing out the
SCCS
directory name:
find . -print -name SCCS -prune
Match only local files, and don't examine the contents of any directory found to be
remotely mounted:
find / ! -local -prune -o -size +50 -print
This only works correctly if there are no local file systems mounted on top of
remote directories. This example will print all local files on the system
larger than 50 blocks, without wasting time accessing remote files.
To get the same effect, but to check for files in local file systems mounted on remote
directories, use:
find / -local -size +50 -print
Exit codes
If find encounters any errors in accessing
operands, it returns non-zero.
Also see the "Compatibility" section, below.
Compatibility
The behavior of the find command was changed (with
UnixWare 7) to conform with the X/Open Command and Utilities
Version 4 Issue 2 standard.
It now returns exit code ``18'' when the directory or file
in the search path does not exist.
Previously, exit code ``0'' was returned.
References
chmod(1),
sh(1),
stat(2),
test(1),
umask(2)
Notices
When using find
to determine files modified within a range of time,
you must use the
?time
arguments before the
-print
argument, or find will return all files.
The following option is obsolete and will not be supported in
future releases.
- -cpio device
-
Always true;
write the current file on
device
in
cpio(1)
format (5120-byte records).
This command has been updated to handle files greater than 2GB.
30 January 1998
© 1998 The Santa Cruz Operation, Inc. All rights reserved.