Я нашел этот вопрос после того, как разобрался со своим подобным сценарием. Кажется, это соответствует вашим условиям и очень гибко, поэтому я решил добавить его в качестве ответа.
Преимущества:
- можно сгруппировать в на любую глубину (0 для
.
, 1 для подкаталогов первого уровня и т. Д.)
- печатает симпатичный вывод
- без цикла, только одна команда
find
, поэтому в больших каталогах это немного быстрее
- все еще можно настроить для добавления пользовательских фильтров (maxdepth, чтобы сделать его нерекурсивным, шаблон имени файла)
Необработанный код:
find -P . -type f | rev | cut -d/ -f2- | rev | \
cut -d/ -f1-2 | cut -d/ -f2- | sort | uniq -c
Обернут в функцию и объяснил:
fc() {
# Usage: fc [depth >= 0, default 1]
# 1. List all files, not following symlinks.
# (Add filters like -maxdepth 1 or -iname='*.jpg' here.)
# 2. Cut off filenames in bulk. Reverse and chop to the
# first / (remove filename). Reverse back.
# 3. Cut everything after the specified depth, so that each line
# contains only the relevant directory path
# 4. Cut off the preceeding '.' unless that's all there is.
# 5. Sort and group to unique lines with count.
find -P . -type f \
| rev | cut -d/ -f2- | rev \
| cut -d/ -f1-$((${1:-1}+1)) \
| cut -d/ -f2- \
| sort | uniq -c
}
Выводит примерно так:
$ fc 0
1668 .
$ fc # depth of 1 is default
6 .
3 .ssh
11 Desktop
44 Downloads
1054 Music
550 Pictures
Конечно, с первым номером его можно передать по номеру sort
:
$ fc | sort
3 .ssh
6 .
11 Desktop
44 Downloads
550 Pictures
1054 Music