私はファイルを持っていると言う
#cat file.log
abc|123|text1 modesc=bpp123 raw_info=clear
abc|123|text2 modesc=pmk123 severity=minor
abc|123|text3 modesc=pnj123 info=good
印刷物$ 3のどの単語が "modesc =" untilスペースの後に表示されるかを知りたいだけです。
そのコマンドの出力が次のようになっていることを強くお勧めします。
abc|123|bpp123
abc|123|pmk123
abc|123|pnj123
Bashを使用して、$ 3が "modesc ="の後にWordを取得する場所を印刷したいと思います。これを行う方法はありますか?
$ sed 's/[^|]*modesc=\([^ ]*\).*$/\1/' file
abc|123|bpp123
abc|123|pmk123
abc|123|pnj123
これは、sed
を使用して、最後のフィールド全体をmodesc=
の後の次のスペースまでの内容に置き換えます。
$ awk -F '|' -vOFS='|' '{ sub(".*modesc=", "", $3); sub(" .*", "", $3)} 1' file
abc|123|bpp123
abc|123|pmk123
abc|123|pnj123
このawk
プログラムは、3番目の列を2つの置換で変更します。 1つ目はmodesc=
までのすべてを削除し、2つ目は最初の残りのスペース以降のすべてを削除します。最後に1
が1つしかない場合、awk
は変更されたレコードを出力します(これは{ print }
に置き換えられる場合があります)。
のみ元のデータの3番目の列からmodesc=
の後の文字列を取得するには(他には何もありません)、上記のコマンドのいずれかを使用してから、それをcut -d '|' -f3
にパイプするか、または
sed 's/.*modesc=\([^ ]*\).*$/\1/' file
または
awk -F '|' -vOFS='|' '{ sub(".*modesc=", "", $3); sub(" .*", "", $3); print $3 }' file
awk
を使用すると、乗算区切り文字を使用して、かなりのサンプルを実行できます。
awk -F'[|= ]' ' {print $1"|" $2"|" $5}' /tmp/file.log
上記の行でパイプ|
、同等の記号=
とスペースは区切り文字です。
次のように、出力区切り文字を明示的に定義できます。
awk -F'[|= ]' 'BEGIN { OFS="|"} {print $1,$2,$5}' /tmp/file.log
これは効率が低下しますが、タスクはcut
およびpaste
にうまく適合します
paste -d '|' <(cut -d'|' -f1-2 file.log) <(cut -d'|' -f3 file.log | grep -oP 'modesc=\K\S+')
awk
の使用:
awk -F\| '{print $1"|"$2"|"gensub(/modesc=(.*) .*$/,"\\1","g",$3)}' /tmp/file.log