Comment puis-je trouver des fichiers plus gros / plus petits que x octets?

237

Dans un terminal, comment trouver des fichiers plus gros ou plus petits que x octets?

Je suppose que je peux faire quelque chose comme

find . -exec ls -l {} \;

puis dirigez le résultat vers awkpour filtrer par taille de fichier. Mais ne devrait-il pas y avoir un moyen plus facile que cela?

chat de plafond
la source

Réponses:

377

Utilisation:

find . -type f -size +4096c

pour trouver des fichiers de plus de 4096 octets.

Et :

find . -type f -size -4096c

pour trouver des fichiers plus petits que 4096 octets.

Remarquez la différence + et - après le changement de taille.

Le -sizecommutateur a expliqué:

-size n[cwbkMG]

    File uses n units of space. The following suffixes can be used:

    `b'    for 512-byte blocks (this is the default if no suffix  is
                                used)

    `c'    for bytes

    `w'    for two-byte words

    `k'    for Kilobytes       (units of 1024 bytes)

    `M'    for Megabytes    (units of 1048576 bytes)

    `G'    for Gigabytes (units of 1073741824 bytes)

    The size does not count indirect blocks, but it does count
    blocks in sparse files that are not actually allocated. Bear in
    mind that the `%k' and `%b' format specifiers of -printf handle
    sparse files differently. The `b' suffix always denotes
    512-byte blocks and never 1 Kilobyte blocks, which is different
    to the behaviour of -ls.
John T
la source
11
@Jay: Dans man, trouvez au début de la section "Tests": "Les arguments numériques peuvent être spécifiés avec + n pour les valeurs supérieures à n, -n pour les valeurs inférieures à n, n pour exactement n."
Dennis Williamson
4
La page de manuel le mentionne vers le haut et décrit que + et - peuvent s'appliquer à tous les commutateurs utilisant des arguments numériques ('n'), y compris ce que + et - signifient. (Recherchez TESTS dans la page de manuel pour trouver le début de la section où cela est décrit)
Slartibartfast
1
@ Dennis Williamson: bizarre, + et - fonctionnent sous OS X, mais la page de manuel ne contient pas la section TESTS. En fait, il manque un gros morceau par rapport à votre lien, il manque des tests, des actions, des opérateurs, entre autres.
chat de plafond
1
Il semble que la version GNU de la page de manuel comporte la section "Tests", mais pas la version BSD. linuxmanpages.com/man1/find.1.php
Jay
8
Je viens de découvrir que les pages de manuel BSD décrivent le +/-. Son chemin à la fin de la section "Primaires". - Toutes les primaires utilisant un argument numérique permettent au numéro d'être précédé d'un signe plus (“+”) ou d'un signe moins (“-”). Un signe plus précédent signifie «plus que n», un signe moins précédent signifie «moins que n» et ni l'un ni l'autre ne signifie «exactement n»
Jay
7

Je pense que findpourrait être utile seul sans canalisation à AWK. Par exemple,

find ~ -type f -size +2k  -exec ls -sh {} \;

Le tilde indique où vous voulez que votre recherche commence et le résultat ne doit afficher que les fichiers de plus de 2 kilo-octets.

Pour vous simplifier la tâche, vous pouvez utiliser l' -execoption permettant d'exécuter une autre commande consistant à répertorier ces répertoires avec leurs tailles.

Pour plus d'informations, lisez la page de manuel defind .

Siobhan
la source
4

AWK est vraiment très facile pour ce genre de chose. Voici certaines choses que vous pouvez faire avec la vérification de la taille du fichier, comme vous l'avez demandé:

Lister les fichiers de plus de 200 octets:

ls -l | awk '{if ($5 > 200) print $8}'

Répertoriez les fichiers de moins de 200 octets et écrivez la liste dans un fichier:

ls -l | awk '{if ($5 < 200) print $8}' | tee -a filelog

Répertoriez les fichiers de 0 octet, enregistrez la liste dans un fichier et supprimez les fichiers vides:

ls -l | awk '{if ($5 == 0) print $8}' | tee -a deletelog | xargs rm
MaQleod
la source
Quelle est la différence entre teeun redirection vers et un redirection vers un fichier, du type ls -l > filelog(ou ls -l >> filelog)?
OmarOthman
3

Plus de 2000 octets:

du -a . | awk '$1*512 > 2000 {print $2}'

Moins de 2000 octets:

du -a . | awk '$1*512 < 2000 {print $2} '
Geai
la source
C’est grave car cela donne l’espace occupé sur le disque. Ce n'est pas la même chose qu'une taille de fichier. Par exemple, si vous avez un système de fichiers compressé (btrfs / zfs), du vous donnera un résultat différent de celui de ls qui indique la taille réelle décompressée.
Chris Scott