私は標準出力を持っています:
jh888636 4533 cklsls 55885
sp838922 7373 ksshhs 77321
dp828273 8722 kiwjkk 72661
検索する静的ファイルは次のとおりです。
"ah768889"|"Aron Hease"|"Louis Jid"|"99949"
"jh888636"|"John Holmes"|"Peter King"|"60036"
"sp838922"|"Steven Parn"|"Jay Walker"|"60004"
"dp828273"|"David Pim"|"Kate Jast"|"89488"
私の目標は、stdoutの列1を静的ファイルの列1と一致させ、列2/4などを抽出/印刷することです。
望ましい出力の例:
John Holmes (60036) 4533 cklsls 55885
Steven Parn (60004) 7373 ksshhs 77321
David Pim (89488) 8722 kiwjkk 72661
答え1
別のawk
方法:
... |awk 'NR==FNR{one=$1;$1="";seen[one]=$0; next}
{FS="[|\"]"} seen[$2]{printf ("%s (%s) %s\n", $5, $(NF-1), seen[$2])}' - static
出力は次のとおりです。
John Holmes (60036) 4533 cklsls 55885
Steven Parn (60004) 7373 ksshhs 77321
David Pim (89488) 8722 kiwjkk 72661
上記の- static
ダッシュは次のことを-
意味します。アッ標準入力から読み取ることは次のとおりですstatic
。静的ファイル。
答え2
私は4段階にしました。
sed "s/|/ /g" staticfile_lookup | sed 's/"//g' >> static_file_lookup_final.txt
awk 'NR==FNR{a[$1];next}($1 in a){print $2,$3,$NF}' stdout static_file_lookup_final.txt >>static_file_lookup_fina1_1.txt
awk '{$1="";print $0}' stdout >>stdout_final.txt
=========
cat static_file_lookup_fina1_1.txt
John Holmes 60036
Steven Parn 60004
David Pim 89488
===========
cat stdout_final.txt
4533 cklsls 55885
7373 ksshhs 77321
8722 kiwjkk 72661
=================
paste static_file_lookup_fina1_1.txt stdout_final.txt
出力
John Holmes 60036 4533 cklsls 55885
Steven Parn 60004 7373 ksshhs 77321
David Pim 89488 8722 kiwjkk 72661