Puede usar GNU en paralelo para hacerlo, ya que puede limitar el número de elementos a un trabajo, así como proporcionar un número de trabajo (para un nombre de archivo zip único):
$ 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
La opción -N 5
limita el número de archivos a 5 por archivo y se presenta zip
en lugar de{}
El {#}
(literalmente, no debe ser reemplazado por usted durante la invocación), se reemplaza por el número de trabajo, lo que da como resultado arch1.zip
, arch2.zip
etc.
La -print0
opción de find
y -0
opción de parallel
la par asegurarse de que los nombres de archivo con caracteres especiales se manejan correctamente.