Назад | Перейти на главную страницу

Получить все расширения и соответствующее количество файлов в каталоге

Получение всех расширений для каталога: легко. Получение количества файлов для определенного расширения: просто.

Но получение всех расширений файлов и их соответствующего количества файлов намекает на меня.

например.

+ dir
 + abc.txt
 + def.txt
 + abc.pdf
 * def.pov

должен вернуть что-то вроде:

.txt 2
.pdf 1
.pov 1

Цель этого упражнения - выяснить, какое расширение файла является популярным в определенном каталоге.

заранее спасибо

/var/cache$ sudo find ./ -type f | grep -E ".*\.[a-zA-Z0-9]*$" | sed -e 's/.*\(\.[a-zA-Z0-9]*\)$/\1/' | sort | uniq -c | sort -n
      1 .6
      1 .cache
      1 .noconf
      1 .php
      1 .sl
      2 .bin
      2 .el
      2 .tdb
      4 .baseA
      4 .baseB
      4 .dat
      4 .DB
     27 .db
    221 .deb

Вот объяснение:

find ./ -type f

найти только файл, а не каталог

grep -E ".*\.[a-zA-Z0-9]*$"

файл фильтра с расширением

sed -e 's/.*\(\.[a-zA-Z0-9]*\)$/\1/'

удалить путь и имя файла, сохранить только расширение

sort | uniq -c | sort -n

сортировать, унифицировать и сортировать

Поскольку вы используете Linux (gnu grep), сейчас хорошее время для использования Perl RE (PCRE) -P и grep -o вариант. Принимая ответ @bindbn как отличный кандидат:

find . -type f | grep -Po '\.([\w\d])*$' | sort | uniq -c | sort -n