Find

Från Wiki.linux.se
Version från den 17 oktober 2023 kl. 10.45 av Admin (diskussion | bidrag)
Hoppa till navigering Hoppa till sök

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 felsöker Skriv ut  diagnostisk information; detta kan vara till hjälp för att diagnostisera problem med varför find inte gör som du vill. Listan över felsökningsalternativ ska vara kommaseparerad. Kompatibilitet för felsökningsalternativen garanteras inte mellan utgåvor av findutils. För en fullständig lista över giltiga felsökningsalternativ, se utdata från find -D hjälp. Giltiga felsökningsalternativ inkluderar

exec   Visa diagnostisk information om -exec, -execdir, -ok och -okdir

opt    Skriver ut diagnostisk information relaterad till optimeringen av uttrycksträdet; se alternativet -O.

priser  Skriver ut en sammanfattning som anger hur ofta varje predikat lyckades eller misslyckades.

sök Navigera utförligt i katalogträdet.

stat   Skriv ut meddelanden som filer granskas med stat- och lstat-systemanropen. Sökprogrammet försöker minimera sådana samtal.

träd   Visa uttrycksträdet i dess ursprungliga och optimerade form.

alla    Aktivera alla andra felsökningsalternativ (men hjälp).

hjälp   Förklara felsökningsalternativen.

-Olevel

Aktiverar frågeoptimering. Find-programmet ordnar om tester för att påskynda exekveringen samtidigt som den övergripande effekten bevaras; det vill säga predikat med biverkningar är inte omordnade i förhållande till varandra. Optimeringarna som utförs på varje optimeringsnivå är följande.

0      Motsvarar optimeringsnivå 1.

1      Detta är standardoptimeringsnivån och motsvarar det traditionella beteendet. Uttrycken ordnas om så att tester baserat enbart på filnamnen (till exempel -namn och -regex) utförs först.

2      Alla  -type - eller -xtype-tester utförs efter eventuella tester som endast baseras på filnamnen, men före alla tester som kräver information från inoden. På många moderna versioner av Unix returneras filtyper av readdir() och därför är dessa predikat snabbare att utvärdera än predikat som måste ange filen först. Om du använder -fstype FOO-predikatet och anger en filsystemstyp FOO som inte är känd (det vill säga finns i `/etc/mtab') vid den tidpunkt då sökningen startar, är det predikatet ekvivalent med -false.

3      På denna optimeringsnivå är den fullständiga kostnadsbaserade frågeoptimeraren aktiverad. Testordningen ändras så att billiga (dvs. snabba) tester utförs först och dyrare utförs senare, om det behövs. Inom varje kostnadsband utvärderas predikat tidigare eller senare beroende på om de sannolikt kommer att lyckas eller inte. För -o utvärderas predikat som sannolikt kommer att lyckas tidigare, och för -a utvärderas predikat som sannolikt kommer att misslyckas tidigare.

Den kostnadsbaserade optimeraren  har  en fast uppfattning om hur sannolikt ett givet test är att lyckas. I vissa fall tar sannolikheten hänsyn till testets specifika karaktär (t.ex. antas -typ f vara mer sannolikt att lyckas än -typ c). Den kostnadsbaserade optimeraren  utvärderas för närvarande. Om det inte faktiskt förbättrar prestandan för hitta kommer det att tas bort igen. Omvänt kan optimeringar som visar sig vara tillförlitliga, robusta och effektiva aktiveras på lägre optimeringsnivåer över tid. Standardbeteendet (d.v.s. optimeringsnivå 1) kommer dock inte att ändras i version 4.3.x. Findutils testsvit kör alla tester på hitta på varje optimeringsnivå och säkerställer att resultatet är detsamma.

Den del av kommandoraden efter listan med startpunkter är uttrycket. Det här är en typ av frågespecifikation som beskriver hur vi matchar filer och vad vi gör med filerna som matchades. Ett uttryck består av en sekvens av saker: Tester Tester  returnerar ett sant eller falskt värde, vanligtvis på grundval av någon egenskap hos en fil som vi överväger. Testet -empty är till exempel sant  endast när den aktuella filen är tom.

Åtgärder

Åtgärder har bieffekter (som att skriva ut något på standardutdata) och returnerar antingen sant eller falskt, vanligtvis baserat på om de är framgångsrika eller inte. Åtgärden -print skriver till exempel ut namnet på den aktuella filen på standardutdata.

UTTRYCK

Globala alternativ

Globala alternativ påverkar driften av tester och åtgärder som anges på någon del av kommandoraden. Globala alternativ returnerar alltid sant. Djupalternativet gör till exempel att hitta passerar filsystemet i en djup-första ordning. Positionsalternativ Positionsalternativ påverkar endast tester eller åtgärder som följer dem. Positionsalternativ returnerar alltid sant. Alternativet -regextype är till exempel positionellt, och anger dialekten för reguljära uttryck för reguljära uttryck som förekommer senare på kommandoraden.

Operatörer

Operatörer sammanfogar de andra objekten i uttrycket. De inkluderar till exempel -o (som betyder logiskt ELLER) och -a (som betyder logiskt OCH). Där en operatör saknas antas -a.

Åtgärden -print utförs på alla filer för vilka hela uttrycket är sant, såvida det inte innehåller en annan åtgärd än -prune eller -quit.

Åtgärder som förhindrar standard -print är -delete, -exec, -execdir, -ok, -okdir, -fls, -print, -fprintf, -ls, -print och -printf. Åtgärden -delete fungerar också som ett alternativ (eftersom det innebär -djup).

POSITIONELLA ALTERNATIV

Positionsalternativ returnerar alltid sant. De påverkar endast tester som inträffar senare på kommandoraden.

-dagens start

Mät tider  (för -amin, -atime, -cmin, -ctime, -mmin och -mtime) från början av idag snarare än från 24 timmar sedan. Det här alternativet påverkar bara tester som visas senare på kommandoraden.

-daystart

Utfasad; använd alternativet -L istället. Avlägsna symboliska länkar. Antyder -noleaf. Alternativet -follow påverkar endast de tester som  visas  efter det på kommandoraden. Om inte alternativet -H eller -L har specificerats, ändrar positionen för -follow-alternativet beteendet för predikatet -newer; alla filer som listas som argumentet för -newer kommer att hänvisas bort om de är symboliska länkar. Samma övervägande gäller för -newerXY, -anewer och -cnewer. På samma sätt kommer predikatet -type alltid att matcha den typ av fil som en symbolisk länk pekar på snarare än själva länken. Att använda -follow gör att predikaten -lname och -ilname alltid returnerar falskt.

-regextype type

Ändrar syntaxen för reguljära uttryck som förstås av -regex- och -iregex-test som inträffar senare på kommandoraden. Om du vill se vilka typer av reguljära uttryck som är kända använder du hjälpen -regextype. Texinfo-dokumentationen (se SE ÄVEN) förklarar innebörden av och skillnaderna mellan de olika typerna av reguljära uttryck.

-warn, -nowarn

Slå på eller av varningsmeddelanden. Dessa varningar gäller endast för användning av kommandoraden, inte för någon villkor som kan uppstå när den söker i kataloger. Standardbeteendet verensstämmer svarar för att -warn om standardinmatning är en tty, och att -nowarn annars. Om ett varningsmeddelande gäller när kommandoradsanvändning produceras, påverkas inte utgångsstatusen för hitta. Om  POSIXLY_CORRECT miljövariabel är inställd, och -warn används också, det anges inte vilken, om    varningar kommer att vara aktiva.

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  specify 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.