変数をどのように書くのかわかりません。sed
したがって、forループを使用して次のことをしたいと思います。
sed -n '1,200p' big_file.txt> 1to200.txt sed -n '201,400p' big_file.txt> 201to400.txt sed -n '401,600p' big_file.txt> 401to600.txt sed -n '601,800p' big_file.txt> 601to800.txt sed -n '801,1000p' big_file.txt> 801to1000.txt sed -n '1001,1200p' big_file.txt> 1001to1200.txt sed -n '1201,1400p' big_file.txt> 1201to1400.txt sed -n '1401,1600p' big_file.txt> 1401to1600.txt sed -n '1601,1800p' big_file.txt> 1601to1800.txt sed -n '1801,2000p' big_file.txt> 1801to2000.txt sed -n '2001,2200p' big_file.txt> 2001to2200.txt sed -n '2201,2400p' big_file.txt> 2201to2400.txt sed -n '2401,2600p' big_file.txt> 2401to2600.txt sed -n '2601,2800p' big_file.txt> 2601to2800.txt sed -n '2801,3000p' big_file.txt> 2801to3000.txt sed -n '3001,3200p' big_file.txt> 3001to3200.txt sed -n '3201,3400p' big_file.txt> 3201to3400.txt sed -n '3401,3600p' big_file.txt> 3401to3600.txt sed -n '3601,3800p' big_file.txt> 3601to3800.txt sed -n '3801,4000p' big_file.txt> 3801to4000.txt
私が試したこと:
j=0
for ((i=1;i<=3801;i=$i+200))
do
#echo $m,$n
j=$j + 200
sed -n '$i,$j p' big_file.txt > $ito$j.txt
done
私がこれをするのを手伝ってください。説明をお願いします。
答え1
sedを呼び出す代わりに、awkプログラムを使用してこれを行います。窒素移流
awk '
BEGIN {incr = 200; i=1-incr; j=0}
NR % incr == 1 {
i += incr
j += incr
close(out)
out = i "to" j ".txt"
}
{print > out}
' big_file.txt
大容量ファイルを 4000¼200=20 回ではなく 1 回だけ処理すればよいので、速度が速くなります。
答え2
閉鎖。
では、j=$j + 200
算術拡張(たとえば)を明示的に呼び出す必要がありますj=$(( j + 200 ))
。
sed -n '$i,$j p' big_file.txt > $ito$j.txt
1)引数に一重引用符の代わりに二重引用符を使用する必要がありますsed
。それ以外の場合は、文字通り受け入れられ、変数は拡張されません。 2)有効な変数になるため、$
これを中括弧で囲む必要があります。拡張。i
$ito
$
また、算術的文脈では、変数名の前にuseを使用する必要はなく、おそらくそうしてはいけません。
だから私はそれを次のように書きました:
j=0
for (( i = 1 ; i <= 3801 ; i = i + 200)); do
j=$((j + 200))
sed -n "$i,$j p" big_file.txt > "${i}to$j.txt"
done
他の人が述べたように、おそらくより良い方法があります。これで、分割の各部分についてファイルを完全に一度見てみることができるからです。