Questão Como posso encontrar arquivos maiores / menores que x bytes?


Em um terminal, como posso encontrar arquivos maiores ou menores que x bytes?

Eu suponho que eu possa fazer algo como

find . -exec ls -l {} \;

e depois canalizar o resultado para awk para filtrar por tamanho de arquivo. Mas não deveria haver um caminho mais fácil do que isso?


183


origem




Respostas:


Usar:

find . -type f -size +4096c

para encontrar arquivos maiores que 4096 bytes.

E:

find . -type f -size -4096c

para encontrar arquivos menores que 4096 bytes.

Observe a diferença + e - após o interruptor de tamanho.

o -size interruptor explicado:

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

285



@Jay: De encontrar homem no início da seção "Tests": "Argumentos numéricos podem ser especificados como + n para maior que n, -n para menos que n, n para exatamente n." - Dennis Williamson
A man page a menciona no topo e descreve que + e - podem se aplicar a todas as opções que usam argumentos numéricos ('n'), incluindo o que significa + e -. (Procure por TESTS na página man para encontrar o começo da seção onde isso é descrito) - Slartibartfast
Parece que a versão GNU da man page tem a seção "Tests", mas a versão do BSD não. linuxmanpages.com/man1/find.1.php - Jay
A man page do solaris possui uma seção "Expressão" que também explica isso. docs.sun.com/app/docs/doc/816-0210/6m6nb7m9j?l=en&a=view - Jay
Acabei de descobrir que as páginas man do BSD descrevem a coisa +/-. Seu caminho no final da seção "Primários". - Todas as primárias que aceitam um argumento numérico permitem que o número seja precedido por um sinal de mais (“+”) ou um sinal de menos (“-”). Um sinal de mais precedente significa “mais do que n”, um sinal de menos anterior significa “menor que n” e nenhum deles significa “exatamente n” - Jay


eu acho que find pode ser útil sozinho sem canalizar para o AWK. Por exemplo,

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

O til indica onde você deseja que sua pesquisa comece e o resultado deve exibir apenas arquivos maiores que 2 kilobytes.

Para torná-lo chique, você pode usar o -exec opção para executar outro comando que é listar esses diretórios com seus tamanhos.

Para mais informações, leia o página de manual para find.


6





O AWK é realmente muito fácil para esse tipo de coisa. Aqui estão algumas coisas que você pode fazer em relação à verificação do tamanho do arquivo, como você perguntou:

Listar arquivos com mais de 200 bytes:

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

Listar arquivos com menos de 200 bytes e gravar a lista em um arquivo:

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

Listar arquivos de 0 bytes, gravar a lista em um arquivo e excluir os arquivos vazios:

ls -l | awk '{if ($5 == 0) print $8}' | tee -a deletelog | xargs rm

4



análise ls não é bom - phuclv
Qual é a diferença entre a tubulação tee e apenas redirecionando para um arquivo, como ls -l > filelog (ou ls -l >> filelog)? - OmarOthman


Maior que 2000 bytes:

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

Menos de 2000 bytes:

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

3