Пример У меня есть каталог ввода, как показано ниже, с двумя ветвями на 2-м уровне (2 и 22)
~/input_directory/1/2/3/4/5/6
~/input_directory/1/22/3/4/5/6
Я хочу запустить команду для заполнения ~/output_directory
с одноуровневым подкаталогом, который содержит (пустые) подкаталоги с этими именами, поэтому единственный подкаталог в output_directory просто сглаживается как
./1 ./2 ./22 ./3 ./4 ./5 ./6
Исходный каталог input_directory не изменился.
С помощью
find . -type d -exec echo {} \;
дает
./1
./1/2
./1/2/3
./1/2/3/4
./1/2/3/4/5
./1/2/3/4/5/6
./1/22
./1/22/3
./1/22/3/4
./1/22/3/4/5
./1/22/3/4/5/6
Я думал, это сработает:
find . -type d -maxdepth 10 -print0 | xargs -0 mkdir -p ~/output_folder
но, к сожалению, нет (с параметром -maxdepth или без него на всякий случай).
find . -type d -maxdepth 10 -print0 | xargs -0 ls -al
правильно выполняет, так что его почти там?
Благодарен за помощь.
Не уверен, что вы этого хотите, так как я не совсем понял, почему вы этого хотите, но вы можете попробовать это
[user@host ~]$ ls 1
2 22
[user@host ~]$ ls -R 1
1:
2 22
1/2:
3
1/2/3:
4
1/2/3/4:
5
1/2/3/4/5:
6
1/2/3/4/5/6:
1/22:
3
1/22/3:
4
1/22/3/4:
5
1/22/3/4/5:
6
1/22/3/4/5/6:
Итак, теперь попробуйте запустить это:
mkdir output_directory; find 1 -type d -exec echo {} \; > dirs.txt; for dir in $(cat dirs.txt); do if [ ! -d output_directory/${dir##*/} ]; then mkdir output_directory/${dir##*/}; fi; done;
[user@host ~]$ ls output_directory/
1 2 22 3 4 5 6
Из отличного ответа Данилы это моя последняя версия.
find . -type d -exec echo {} \; > /tmp/tempdirs.txt; \
for dir in $(cat /tmp/tempdirs.txt); do \
if [ ! -d ~/output_directory/${dir##*/} ]; then \
mkdir -p ~/output_directory/${dir##*/}; \
fi; \
done;
Ты можешь использовать basename
просто захватить последнюю часть пути, найденную find
, вывод результатов через нулевое значение и использование xargs
с участием replace-str
(-I
), чтобы добавить базовое имя в выходной каталог.
find . -type d -exec basename -z {} \; |xargs -I {} -0 mkdir output_directory/{}