Você pode usar o GNU paralelo para fazer isso, pois pode limitar o número de elementos a um trabalho, bem como fornecer um número de trabalho (para um nome de arquivo zip exclusivo):
$ touch $(seq 20)
$ find . ! -name "*.zip" -type f -print0 | parallel -0 -N 5 zip arch{#} {}
adding: 1 (stored 0%)
adding: 10 (stored 0%)
adding: 11 (stored 0%)
adding: 12 (stored 0%)
adding: 13 (stored 0%)
adding: 14 (stored 0%)
adding: 15 (stored 0%)
adding: 16 (stored 0%)
adding: 17 (stored 0%)
adding: 18 (stored 0%)
adding: 19 (stored 0%)
adding: 2 (stored 0%)
adding: 20 (stored 0%)
adding: 3 (stored 0%)
adding: 4 (stored 0%)
adding: 5 (stored 0%)
adding: 6 (stored 0%)
adding: 7 (stored 0%)
adding: 8 (stored 0%)
adding: 9 (stored 0%)
$ ls
1 11 13 15 17 19 20 4 6 8 arch1.zip arch3.zip
10 12 14 16 18 2 3 5 7 9 arch2.zip arch4.zip
A opção -N 5
limita o número de arquivos a 5 por arquivo morto e é apresentada zip
no lugar de{}
O {#}
(literalmente, para não ser substituído por você durante a invocação), é substituído pelo número do trabalho, resultando em arch1.zip
, arch2.zip
etc.
A -print0
opção find
e a -0
opção parallel
em conjunto garantem que os nomes de arquivos com caracteres especiais sejam manipulados corretamente.