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 awk
pour filtrer par taille de fichier. Mais ne devrait-il pas y avoir un moyen plus facile que cela?
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 commutateur -size
explique:
-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.
Je pense que find
pourrait être utile seul sans canalisation vers 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 vie, vous pouvez utiliser l'option -exec
pour exécuter une autre commande, qui consiste à répertorier ces répertoires avec leurs tailles.
Pour plus d’informations, lisez la page de manuel pour find
.
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 octets, enregistrez la liste dans un fichier et supprimez les fichiers vides:
ls -l | awk '{if ($5 == 0) print $8}' | tee -a deletelog | xargs rm
Plus de 2000 octets:
du -a . | awk '$1*512 > 2000 {print $2}'
Moins de 2000 octets:
du -a . | awk '$1*512 < 2000 {print $2} '