awk -vf=3 -vl="`wc -l file`" 'BEGIN{p=int(l/f);q=(l%f);for(n=1;n<=f;n++)a[n]=n*p+((n<=q)?++x:x)}{if(NR>a[i])i++;print >"file"i}' file
这里的-vf=3 表示将file拆分成3个文件,另外还有一种解法,如下所示:
#!/bin/bash if [ $# -ne 2 ];then echo "U: sh $0 [file] [fnumber]" echo "E: sh $0 myfile 3" exit 1 fi srcfile=$1 #原始文件 fnumber=$2 #需要拆分的文件个数 eval $(cat $srcfile | awk -vn=$fnumber 'END{print "total="NR,"fline="int(NR/n),"extra="NR%n,"cline="int(NR/n)+1}') # total:原始文件总行数 # fline:拆分文件平均行数 # extra:需要扩展行数的文件个数 # cline:当前拆分文件行数 i=1 iline=1 while true;do filename="file$i" # 按行的顺序分别写入文件中 if [ $extra = 0 ];then echo "$filename lines: $fline" tail -n +$iline $srcfile | head -n $fline > $filename iline=$((iline+fline)) else echo "$filename lines: $cline" tail -n +$iline $srcfile | head -n $cline > $filename iline=$((iline+cline)) extra=$((extra-1)) fi ((i++)) [ $iline -ge $total ] && exit 0 done