Find: Skillnad mellan sidversioner
Ingen redigeringssammanfattning |
Ingen redigeringssammanfattning |
||
Rad 1: | Rad 1: | ||
'''NAMN''' | |||
find -söka efter filer i en kataloghierarki | find -söka efter filer i en kataloghierarki | ||
SYNOPSIS | '''SYNOPSIS''' | ||
find [-H] [-L] [-P] [-D debugopts] [-Olevel] [starting-point...] [expression] | find [-H] [-L] [-P] [-D debugopts] [-Olevel] [starting-point...] [expression] | ||
BESKRIVNING | '''BESKRIVNING''' | ||
Den här manualsidan dokumenterar GNU-versionen av find. GNU find söker i katalogträdet som är rotat vid varje given startpunkt genom att utvärdera det givna uttrycket från vänster till höger, enligt prioriteringsreglerna (se avsnittet OPERATÖRER), tills resultatet är känt (vänster sida är falsk för och operationer , sant för eller), vid vilken punkt sökningen går vidare till nästa filnamn. Om ingen startpunkt anges, `.' är antaget. | Den här manualsidan dokumenterar GNU-versionen av find. GNU find söker i katalogträdet som är rotat vid varje given startpunkt genom att utvärdera det givna uttrycket från vänster till höger, enligt prioriteringsreglerna (se avsnittet OPERATÖRER), tills resultatet är känt (vänster sida är falsk för och operationer , sant för eller), vid vilken punkt sökningen går vidare till nästa filnamn. Om ingen startpunkt anges, `.' är antaget. | ||
Rad 21: | Rad 21: | ||
-L Följ symboliska länkar. När find undersöker eller skriver ut information om filer, ska informationen som används hämtas från egenskaperna för filen till som länken pekar, inte från själva länken (såvida det inte är en trasig symbolisk länk eller fyndet inte kan granska filen till vilken länkpunkterna). Användning av detta alternativ innebär -noleaf. Om du senare använder alternativet -P, kommer -noleaf fortfarande att gälla. Om -L är i kraft och find upptäcker en symbolisk länk till en underkatalog under sin sökning, kommer underkatalogen som den symboliska länken pekar på att sökas igenom. När av alternativet -L þess’ bli’ om om predikatet -type är att matcha mot den typ av fil som en symbolisk länk pekar på istället för själva länken (såvida inte den symboliska länken är bruten). Åtgärder som kan orsaka att symboliska länkar bryts medan find körs (till exempel -delete) kan ge upphov till förvirrande beteende. Att använda -L gör att predikaten -lname och -ilname alltid returnerar fals | -L Följ symboliska länkar. När find undersöker eller skriver ut information om filer, ska informationen som används hämtas från egenskaperna för filen till som länken pekar, inte från själva länken (såvida det inte är en trasig symbolisk länk eller fyndet inte kan granska filen till vilken länkpunkterna). Användning av detta alternativ innebär -noleaf. Om du senare använder alternativet -P, kommer -noleaf fortfarande att gälla. Om -L är i kraft och find upptäcker en symbolisk länk till en underkatalog under sin sökning, kommer underkatalogen som den symboliska länken pekar på att sökas igenom. När av alternativet -L þess’ bli’ om om predikatet -type är att matcha mot den typ av fil som en symbolisk länk pekar på istället för själva länken (såvida inte den symboliska länken är bruten). Åtgärder som kan orsaka att symboliska länkar bryts medan find körs (till exempel -delete) kan ge upphov till förvirrande beteende. Att använda -L gör att predikaten -lname och -ilname alltid returnerar fals | ||
Följ inte symboliska länkar, förutom när du bearbetar kommandoradsargumenten. När find undersöker eller skriver ut information om filer, ska informationen som används hämtas från egenskaperna för själva den symboliska länken. Det enda undantaget från detta beteende är när en fil som anges på kommandoraden är en symbolisk länk och länken kan lösas. För den situationen tas informationen som används från vad länken än pekar på (det vill säga länken följs). Informationen om själva länken används som en reserv om filen som den symboliska länken pekar på inte kan granskas. Om -H är i kraft och en av sökvägarna som anges på kommandoraden är en symbolisk länk till en katalog, kommer innehållet i den katalogen att undersökas (även om -maxdepth 0 naturligtvis skulle förhindra detta). | |||
Om mer än en av -H, -L och -P specificeras, åsidosätter var och en de andra; den sista som visas på kommandoraden träder i kraft. Eftersom det är standard, bör -P-alternativet anses vara aktivt om inte antingen -H eller -L anges. GNU hittar ofta statistikfiler under bearbetningen av själva kommandoraden, innan någon sökning har börjat. Dessa alternativ påverkar också hur dessa argument behandlas. Specifikt finns det ett antal tester som jämför filer listade på kommandoraden mot en fil vi för närvarande överväger. I varje fall kommer filen som anges på kommandoraden att ha undersökts och några av dess egenskaper kommer att ha sparats. | |||
-D debugopts Print diagnostic information; this can be helpful to diagnose problems with why find is not doing what you want. The list of debug options should be comma separated. Compatibility of the debug options is not guaranteed between releases of findutils. For a complete list of valid debug options, see the output of find -D help. Valid debug options include | -D debugopts Print diagnostic information; this can be helpful to diagnose problems with why find is not doing what you want. The list of debug options should be comma separated. Compatibility of the debug options is not guaranteed between releases of findutils. For a complete list of valid debug options, see the output of find -D help. Valid debug options include |
Versionen från 25 september 2022 kl. 10.59
NAMN
find -söka efter filer i en kataloghierarki
SYNOPSIS
find [-H] [-L] [-P] [-D debugopts] [-Olevel] [starting-point...] [expression]
BESKRIVNING
Den här manualsidan dokumenterar GNU-versionen av find. GNU find söker i katalogträdet som är rotat vid varje given startpunkt genom att utvärdera det givna uttrycket från vänster till höger, enligt prioriteringsreglerna (se avsnittet OPERATÖRER), tills resultatet är känt (vänster sida är falsk för och operationer , sant för eller), vid vilken punkt sökningen går vidare till nästa filnamn. Om ingen startpunkt anges, `.' är antaget.
Om du använder find i en miljö där säkerhet är viktig (till exempel om du använder den för att söka i kataloger som är skrivbara av andra användare), bör du läsa kapitlet "Security Considerations" i findutils-dokumentationen, som kallas Finding Files och kommer med findutils. Det dokumentet innehåller också mycket mer detaljer och diskussion än den här manualsidan, så du kanske tycker att det är en mer användbar informationskälla.
ALTERNATIV
Alternativen -H, -L och -P styr behandlingen av symboliska länkar. Kommandoradsargument som följer efter dessa anses vara namn på filer eller kataloger som ska undersökas, upp till det första argumentet som börjar med `-', eller argumentet `(' eller `!'. Det argumentet och alla följande argument tas att vara uttrycket som beskriver vad som ska sökas efter. Om inga sökvägar anges används den aktuella katalogen. Om inget uttryck anges används uttrycket -print (men du bör nog överväga att använda -print0 istället, ändå). Den här manualsidan talar om "alternativ" i uttryckslistan. Dessa alternativ styr beteendet för hitta men specificeras omedelbart efter det sista sökvägsnamnet. De fem "riktiga" alternativen -H, -L, -P, -D och -O måste visas före det första sökvägsnamnet, om det överhuvudtaget finns. Ett dubbelstreck -- skulle teoretiskt sett kunna användas för att signalera att eventuella kvarvarande argument inte är alternativ, men detta fungerar inte riktigt på grund av hur hitta bestämmer slutet av följande sökvägsargument : det gör det genom att läsa tills ett uttrycksargument kommer (som också börjar med en `-'). Om nu ett sökvägsargument skulle börja med ett "-", så skulle find behandla det som ett uttrycksargument istället. För att säkerställa att alla startpunkter tas som sådana, och särskilt för att förhindra att jokerteckensmönster som expanderas av det anropande skalet inte av misstag behandlas som uttrycksargument, är det generellt sett säkrare att prefixa jokertecken eller tvivelaktiga sökvägsnamn med antingen `./' eller för att använda absoluta sökvägsnamn som börjar med '/'.
-P Följ aldrig symboliska länkar. Detta är standardbeteendet. När find undersöker eller skriver ut information om filer, och filen är en symbolisk länk, ska informationen som används hämtas från egenskaperna för själva den symboliska länken.
-L Följ symboliska länkar. När find undersöker eller skriver ut information om filer, ska informationen som används hämtas från egenskaperna för filen till som länken pekar, inte från själva länken (såvida det inte är en trasig symbolisk länk eller fyndet inte kan granska filen till vilken länkpunkterna). Användning av detta alternativ innebär -noleaf. Om du senare använder alternativet -P, kommer -noleaf fortfarande att gälla. Om -L är i kraft och find upptäcker en symbolisk länk till en underkatalog under sin sökning, kommer underkatalogen som den symboliska länken pekar på att sökas igenom. När av alternativet -L þess’ bli’ om om predikatet -type är att matcha mot den typ av fil som en symbolisk länk pekar på istället för själva länken (såvida inte den symboliska länken är bruten). Åtgärder som kan orsaka att symboliska länkar bryts medan find körs (till exempel -delete) kan ge upphov till förvirrande beteende. Att använda -L gör att predikaten -lname och -ilname alltid returnerar fals
Följ inte symboliska länkar, förutom när du bearbetar kommandoradsargumenten. När find undersöker eller skriver ut information om filer, ska informationen som används hämtas från egenskaperna för själva den symboliska länken. Det enda undantaget från detta beteende är när en fil som anges på kommandoraden är en symbolisk länk och länken kan lösas. För den situationen tas informationen som används från vad länken än pekar på (det vill säga länken följs). Informationen om själva länken används som en reserv om filen som den symboliska länken pekar på inte kan granskas. Om -H är i kraft och en av sökvägarna som anges på kommandoraden är en symbolisk länk till en katalog, kommer innehållet i den katalogen att undersökas (även om -maxdepth 0 naturligtvis skulle förhindra detta).
Om mer än en av -H, -L och -P specificeras, åsidosätter var och en de andra; den sista som visas på kommandoraden träder i kraft. Eftersom det är standard, bör -P-alternativet anses vara aktivt om inte antingen -H eller -L anges. GNU hittar ofta statistikfiler under bearbetningen av själva kommandoraden, innan någon sökning har börjat. Dessa alternativ påverkar också hur dessa argument behandlas. Specifikt finns det ett antal tester som jämför filer listade på kommandoraden mot en fil vi för närvarande överväger. I varje fall kommer filen som anges på kommandoraden att ha undersökts och några av dess egenskaper kommer att ha sparats.
-D debugopts Print diagnostic information; this can be helpful to diagnose problems with why find is not doing what you want. The list of debug options should be comma separated. Compatibility of the debug options is not guaranteed between releases of findutils. For a complete list of valid debug options, see the output of find -D help. Valid debug options include
exec Show diagnostic information relating to -exec, -execdir, -ok and -okdir
opt Prints diagnostic information relating to the optimisation of the expression tree; see the -O option.
rates Prints a summary indicating how often each predicate succeeded or failed.
search Navigate the directory tree verbosely.
stat Print messages as files are examined with the stat and lstat system calls. The find program tries to minimise such calls.
tree Show the expression tree in its original and optimised form.
all Enable all of the other debug options (but help).
help Explain the debugging options.
-Olevel
Enables query optimisation. The find program reorders tests to speed up execution while preserving the overall effect; that is, predicates with side effects are not reordered relative to each other. The optimisations performed at each optimisation level are as follows.
0 Equivalent to optimisation level 1.
1 This is the default optimisation level and corresponds to the traditional behaviour. Expressions are reordered so that tests based only on the names of files (for example -name and -regex) are performed first.
2 Any -type or -xtype tests are performed after any tests based only on the names of files, but before any tests that require information from the inode. On many modern versions of Unix, file types are returned by readdir() and so these predicates are faster to evaluate than predicates which need to stat the file first. If you use the -fstype FOO predicate and specify a filesystem type FOO which is not known (that is, present in `/etc/mtab') at the time find starts, that predicate is equivalent to -false.
3 At this optimisation level, the full cost-based query optimiser is enabled. The order of tests is modified so that cheap (i.e. fast) tests are performed first and more expensive ones are performed later, if necessary. Within each cost band, predicates are evaluated earlier or later according to whether they are likely to succeed or not. For -o, predicates which are likely to succeed are evaluated earlier, and for -a, predicates which are likely to fail are evaluated earlier.
The cost-based optimiser has a fixed idea of how likely any given test is to succeed. In some cases the probability takes account of the specific nature of the test (for example, -type f is assumed to be more likely to succeed than -type c). The cost-based optimiser is currently being evaluated. If it does not actually improve the performance of find, it will be removed again. Conversely, optimisations that prove to be reliable, robust and effective may be enabled at lower optimisation levels over time. However, the default behaviour (i.e. optimisation level 1) will not be changed in the 4.3.x release series. The findutils test suite runs all the tests on find at each optimisation level and ensures that the result is the same.
EXPRESSION
The part of the command line after the list of starting points is the expression. This is a kind of query specification describing how we match files and what we do with the files that were matched. An expression is composed of a sequence of things: Tests Tests return a true or false value, usually on the basis of some property of a file we are considering. The -empty test for example is true only when the current file is empty.
Actions
Actions have side effects (such as printing something on the standard output) and return either true or false, usually based on whether or not they are successful. The -print action for example prints the name of the current file on the standard output.
Global options
Global options affect the operation of tests and actions specified on any part of the command line. Global options always return true. The depth option for example makes find traverse the file system in a depth-first order. Positional options Positional options affect only tests or actions which follow them. Positional options always return true. The -regextype option for example is positional, specifying the regular expression dialect for regular expressions occurring later on the command line.
Operators
Operators join together the other items within the expression. They include for example -o (meaning logical OR) and -a (meaning logical AND). Where an operator is missing, -a is assumed.
The -print action is performed on all files for which the whole expression is true, unless it contains an action other than -prune or -quit.
Actions which inhibit the default -print are -delete, -exec, -execdir, -ok, -okdir, -fls, -print, -fprintf, -ls, -print and -printf. The -delete action also acts like an option (since it implies -depth).
POSITIONAL OPTIONS
Positional options always return true. They affect only tests occurring later on the command line.
-daystart
Measure times (for -amin, -atime, -cmin, -ctime, -mmin, and -mtime) from the beginning of today rather than from 24 hours ago. This option only affects tests which appear later on the command line.
-follow
Deprecated; use the -L option instead. Dereference symbolic links. Implies -noleaf. The -follow option affects only those tests which appear after it on the command line. Unless the -H or -L option has been specified, the position of the -follow option changes the behaviour of the -newer predicate; any files listed as the argument of -newer will be dereferenced if they are symbolic links. The same consideration applies to -newerXY, -anewer and -cnewer. Similarly, the -type predicate will always match against the type of the file that a symbolic link points to rather than the link itself. Using -follow causes the -lname and -ilname predicates always to return false.
-regextype type
Changes the regular expression syntax understood by -regex and -iregex tests which occur later on the command line. To see which regular expression types are known, use -regextype help. The Texinfo documentation (see SEE ALSO) explains the meaning of and differences between the various types of regular expression.
-warn, -nowarn
Turn warning messages on or off. These warnings apply only to the command line usage, not to any conditions that find might encounter when it searches directories. The default behaviour corresponds to -warn if standard input is a tty, and to -nowarn otherwise. If a warning message relating to command-line usage is produced, the exit status of find is not affected. If the POSIXLY_CORRECT environment variable is set, and -warn is also used, it is not specified which, if any, warnings will be active.
GLOBAL OPTIONS
Global options always return true. Global options take effect even for tests which occur earlier on the command line. To prevent confusion, global
options should specified on the command-line after the list of start points, just before the first test, positional option or action. If you spec‐
ify a global option in some other place, find will issue a warning message explaining that this can be confusing.
The global options occur after the list of start points, and so are not the same kind of option as -L, for example.
-d A synonym for -depth, for compatibility with FreeBSD, NetBSD, MacOS X and OpenBSD.
-depth Process each directory's contents before the directory itself. The -delete action also implies -depth.
-help, --help
Print a summary of the command-line usage of find and exit.
-ignore_readdir_race
Normally, find will emit an error message when it fails to stat a file. If you give this option and a file is deleted between the time find
reads the name of the file from the directory and the time it tries to stat the file, no error message will be issued. This also applies to
files or directories whose names are given on the command line. This option takes effect at the time the command line is read, which means
that you cannot search one part of the filesystem with this option on and part of it with this option off (if you need to do that, you will
need to issue two find commands instead, one with the option and one without it).
Furthermore, find with the -ignore_readdir_race option will ignore errors of the -delete action in the case the file has disappeared since
the parent directory was read: it will not output an error diagnostic, and the return code of the -delete action will be true.
-maxdepth levels
Descend at most levels (a non-negative integer) levels of directories below the starting-points. Using -maxdepth 0 means only apply the
tests and actions to the starting-points themselves.
-mindepth levels
Do not apply any tests or actions at levels less than levels (a non-negative integer). Using -mindepth 1 means process all files except the
starting-points.
-mount Don't descend directories on other filesystems. An alternate name for -xdev, for compatibility with some other versions of find.
-noignore_readdir_race
Turns off the effect of -ignore_readdir_race.
-noleaf
Do not optimize by assuming that directories contain 2 fewer subdirectories than their hard link count. This option is needed when searching filesystems that do not follow the Unix directory-link convention, such as CD-ROM or MS-DOS filesystems or AFS volume mount points. Each directory on a normal Unix filesystem has at least 2 hard links: its name and its `.' entry. Additionally, its subdirectories (if any) each have a `..' entry linked to that directory. When find is examining a directory, after it has statted 2 fewer subdirectories than the directory's link count, it knows that the rest of the entries in the directory are non-directories (`leaf' files in the directory tree). If only the files' names need to be examined, there is no need to stat them; this gives a significant increase in search speed.
-version, --version
Print the find version number and exit.
-xdev Don't descend directories on other filesystems.
TESTS
Some tests, for example -newerXY and -samefile, allow comparison between the file currently being examined and some reference file specified on the command line. When these tests are used, the interpretation of the reference file is determined by the options -H, -L and -P and any previous -fol‐ low, but the reference file is only examined once, at the time the command line is parsed. If the reference file cannot be examined (for example, the stat(2) system call fails for it), an error message is issued, and find exits with a nonzero status.
A numeric argument n can be specified to tests (like -amin, -mtime, -gid, -inum, -links, -size, -uid and -used) as
+n for greater than n,
-n for less than n,
n for exactly n.
Supported tests:
-amin n
File was last accessed less than, more than or exactly n minutes ago.
-anewer reference
Time of the last access of the current file is more recent than that of the last data modification of the reference file. If reference is a
symbolic link and the -H option or the -L option is in effect, then the time of the last data modification of the file it points to is always
used.
-atime n
File was last accessed less than, more than or exactly n*24 hours ago. When find figures out how many 24-hour periods ago the file was last
accessed, any fractional part is ignored, so to match -atime +1, a file has to have been accessed at least two days ago.
-cmin n
File's status was last changed less than, more than or exactly n minutes ago.
-cnewer reference
Time of the last status change of the current file is more recent than that of the last data modification of the reference file. If refer‐
ence is a symbolic link and the -H option or the -L option is in effect, then the time of the last data modification of the file it points to
is always used.
-ctime n
File's status was last changed less than, more than or exactly n*24 hours ago. See the comments for -atime to understand how rounding af‐
fects the interpretation of file status change times.
-empty File is empty and is either a regular file or a directory.
-executable
Matches files which are executable and directories which are searchable (in a file name resolution sense) by the current user. This takes into account access control lists and other permissions artefacts which the -perm test ignores. This test makes use of the access(2) system call, and so can be fooled by NFS servers which do UID mapping (or root-squashing), since many systems implement access(2) in the client's kernel and so cannot make use of the UID mapping information held on the server. Because this test is based only on the result of the access(2) system call, there is no guarantee that a file for which this test succeeds can actually be executed.