Рекурсивно удаляйте файлы размером менее 1МБ

Ответы:

21

Это можно сделать с помощью find:

find . -type f -size -1M -exec rm {} +

Обратите внимание, что это рекурсивно сойдет в подкаталоги и безоговорочно удалит все файлы размером менее 1 мегабайта. Быть осторожен.

Свен Марнах
источник
вам не хватает аргумента пути кfind
@Useless: это GNU find. :)
Свен Марнах
2
@DanielAndersson: findограничивает количество аргументов для вызываемого процесса, чтобы вписаться в ограничения системы, в отличие от того rm *, который гарантированно является одним вызовом процесса. при необходимости findвызовет несколько экземпляров rm. И я уверен, что специальные символы обрабатываются правильно, включая символы новой строки. Я предпочитаю -exec rmболее -deleteиз соображений гибкости - в качестве примера, последний не предлагает способа удаления файлов, защищенных от записи.
Свен Марнач
1
@Invoker: я отменил ваше изменение, так как оно было неверным. -1Mозначает менее одного мегабайта по желанию. Ваша версия удалит все файлы размером ровно в один мегабайт, что выглядит несколько бессмысленной операцией.
Свен Марнах
2
Если вы хотите удалить все файлы размером более 1М, используйте команду find . -type f -size +1M -exec rm {} +. Обратите внимание на + 1M вместо -1M.
chessofnerd
10

Это должно сделать работу:

$ find <directory> -type f -size -1M -delete
jcollado
источник
Я не думаю, что нам нужно дефис в 1M.
Invoker
2
@ Invoker, я считаю, что это -знак минус, означающий «менее 1 млн». Если вы запустите, find <directory> -type f -size +1M -deleteвы удалите все файлы размером более 1M.
chessofnerd
да, ты прав, мой плохой
Invoker
2

Просто для разнообразия и возможного (возможно, предельного) прироста производительности:

find <directory> -type f -size -1M -print0  | xargs -0 rm
Бесполезный
источник
Как это должно быть быстрее? Начинается дополнительный xargsпроцесс.
Свен Марнах
Теперь вы можете иметь два процессора, борющихся за одно и то же блочное устройство! Более разумно, что операции stat / readdir не блокируются синхронно операцией unlink. Вероятность того, что это будет лучше, очевидно, зависит от размера поддерева, количества файлов, устройства и т. Д.
1

Пытаться

находить . -размер -1M -exec rm {} \;

ahvargas
источник
1
Это отлично подходит для пользователей не GNU. Благодарность! такой же, как и у ответа @ Свена, но \;в конце вместо+
hamx0r
-1

Вы можете проверить эту ссылку http://ayaz.wordpress.com/2008/02/05/bash-quickly-deleting-empty-files-in-a-directory/ , она имеет именно то, что вы хотите.

for file in *;
  do
    file_size=$(du $file | awk '{print $1}');
    if [ $file_size == 0 ]; then
        echo "Deleting empty file $file with file size $file_size!";
        echo "rm -f $file";
    fi;
done

Вы можете перебрать все файлы с помощью цикла for, а затем использовать du и awk, чтобы найти размер файла, как в приведенном выше примере.

Стин Шютт
источник
Ответы на SO должны быть автономными - не размещайте просто ссылку. (Более того, код в связанном посте удаляет пустые файлы, а не файлы размером менее 1 млн.)
Свен Марнач
@SvenMarnach не можем использовать $ file_size <1M в приведенной ссылке примера кода.
Нет, мы не можем, так как оболочка не поймет 1M.
Свен Марнах
Под 1М я подразумевал 1048576, преобразовывающий 1МБ в байт
1
Что ж, если вы проверите, действительно ли это работает и скопируете код в свой ответ, это может стать SO-ответом.
Свен Марнах