是否可以创建一个脚本,运行后将创建以下结构:
/test/1/1 -> A
/test/1/2 -> B
/test/1/3 -> C
/test/1/4 -> D
/test/1/5 -> E
/test/1/6 -> F
/test/1/7 -> G
/test/1/8 -> H
/test/1/9 -> I
/test/1/10 -> J
/test/1/11 -> K
/test/1/12 -> L
/test/1/13 -> M
/test/1/14 -> N
/test/1/15 -> O
/test/2/1 -> P
/test/2/2 -> Q
/test/2/3 -> R
/test/2/4 -> S
/test/2/5 -> T
/test/2/6 -> U
/test/2/7 -> V
/test/2/8 -> X
/test/2/9 -> Y
/test/2/10 -> Z
/test/2/11 -> A
/test/2/12 -> B
/test/2/13 -> C
/test/2/14 -> D
/test/2/15 -> E
/test/3/1 -> F
/test/3/2 -> G
/test/3/3 -> H
.........
/test/10/15 -> ???
如您所见,在此示例中,目录“test”是父目录,编号的目录是子目录。这些字母是文件,而不是文件夹。每次字母表结束时,都会从下一个目录的开头开始。
我如何创建一个脚本来使这变得更容易,而不仅仅是手动创建它们?
答案1
和zsh
:
dirs=(test/{1..10}/{1..15}) n=0
mkdir -p $dirs &&
for d ($dirs) {:>$d/$(([##36]n%26+10)); ((n++))}
A
上面的技巧是使用 base36 数字,其中数字 10 到 35 用...表示Z
。会更容易理解和概括:
dirs=(test/{1..10}/{1..15}) n=0 l=({A..Z})
mkdir -p $dirs && for d ($dirs) : > $d/$l[1 + n++ % $#l]
答案2
echo /test/{1..10}/{1..15} " " |
( chars=({A..Z}); i=0;
while read -d " " dir; do
test -z "$dir" && break;
echo mkdir -p "$dir";
echo touch "${dir}/${chars[i]}";
((i++));
i=$((i%26));
done )