私は、埋め込まれたテキストファイルに含める必要がある計算を実行するスクリプトを開発しています。ファイル行の形式は次のとおりです。
1 20/10/16 12:00 take car in the garage joe's garage
スクリプトは、行の最初の数字を置き換える計算から数字を取得します。たとえば、「calculate」は値15を返すと、スクリプトは問題のあるファイルにアクセスし、問題のある行を次のように変更する必要があります。
15 20/10/16 12:00 take car in the garage joe's garage
要点は、この変更を行う方法がわからないことです。 bash、awk、sed、または利用可能なリソースに存在できます。ありがとうございます。
ベストアンサー1
どうですか?
awk -v old=$oldNum -v new=$newNum \
'{if ($1==old) {$1=new; print} else {print}}' input.txt > output.txt
次のように試しました。
$ cat input.txt
2 19/10/16 15:30 some other line
1 20/10/16 12:00 take car in the garage joe's garage
3 17/10/16 5:30 another one
$ oldNum=2
$ newNum=15
awkコマンドを実行したら、次のようにします。
$ cat output.txt
15 19/10/16 15:30 some other line
1 20/10/16 12:00 take car in the garage joe's garage
3 17/10/16 5:30 another one
これはあなたが望むものですか?結果を元のファイルに表示するには、入力ファイルを上書きするmv
新しい名前の出力ファイルだけが必要です(コマンドエイリアスを防ぐにはバックスラッシュを使用してください)。input.txt
\mv
mv
注:短いawk命令を使用しても同じ結果が得られますが、この構文を使用すると読みやすくなります。sed
おそらくこれはより簡潔な方法で行うことができます。
編集:ファイル内の1つの数字のみを変更したい場合は、これが機能することに気づきました。質問を正しく理解したら、数字を再計算したいすべて行を作成し、これらの新しい番号でファイルを作成します。これを行う最善の方法は、新しい行番号の計算を含めることです。~へ、、...などのツールを繰り返し呼び出すことは、最終的に費用がかかる可能性があるawk
ため、一般的に悪い考えです。次のことができます。awk
echo
sed
if [ -f $PWD/output.txt ]; then
# Remove old output if present in current directory
\rm -f $PWD/output.txt
fi
awk '{ ###calculation here, result store in newNum###; $1=newNum; print}' input.txt > output.txt
たとえば、単に各行番号を1ずつ増やすには、次のようにします。
awk '{$1++; print}' input.txt > output.txt
で計算をラップできないか、あえてできない場合は、ファイルに対してawk
ループを実行できますが、bash
スクリプトの私の理解によると、これは非常に不器用です。
if [ -f $PWD/output.txt ]; then
# Remove old output if present in current directory
\rm -f $PWD/output.txt
fi
while read line
do
newNum=###Calculation here for current line###
echo $line | awk -v new=$newNum '$1=new' >> output.txt
done <input.txt