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