2つのファイルを確認して3番目のファイルを作成する必要があります。

2つのファイルを確認して3番目のファイルを作成する必要があります。

File1 - Column1 データのみ、他の列はヘッダのみ。

Column1, column55, column56, column57, column58, column59, column60,column61, column62
123
124
221
225
333
432

ファイル2:

Column1,Column2,Column3,Column4,…………column55, column59, column58, column54, column62, column61
xxx,123,yyy,zzz…….bbb,ccc,ddd,eee,fff,ggg,hhh,c:\a\b\c\ddd,ggg,hhh,c:\a\b\c\dsada,c:\a\b\c\kkja,c:\a\b\c\dsada,c:\a\b\c\kada
xxx,124,xxx,yyy………111,222,333,444,555,vvv,ddd,c:\a\b\c\uuu,ggg,hhh,c:\a\b\c\adada,c:\a\b\c\daa,c:\a\b\c\dsada,c:\a\b\c\kkjj
xxx,221,xxx,yyy………zzz,ddd,333,fff,ccc,ddd,333,c:\a\b\c\vvv,ggg,hhh,c:\a\b\c\dads,c:\a\b\c\adaa,c:\a\b\c\dsada,c:\a\b\c\kkjakjjsa
xxx,333,xxx,yyy………kkk,444,www,333,fff,223,323,c:\a\b\c\xxx,ggg,hhh,c:\a\b\c\dddjj,c:\a\b\c\adaad,c:\a\b\c\dsada,c:\a\b\c\kki2
xxx,787,xxx,yyy………zzz,ddd,333,fff,ccc,ddd,213,c:\a\b\c\yyy,ggg,hhh,c:\a\b\c\dddkf,c:\a\b\c\fasd,c:\a\b\c\dsada,c:\a\b\c\kku3
xxx,827,xxx,yyy………kkk,444,www,333,fff,sda,sda,c:\a\b\c\zzz,ggg,hhh,c:\a\b\c\ddyu,c:\a\b\c\fsssfs,c:\a\b\c\dsada,c:\a\b\c\k233

確認ワークフローは次のとおりです。

  • ファイル1の列1 =ファイル2の列2の場合。 — ヘッダーとデータを比較し
    (file1.column55 = file2.column55. — 同じ場合はヘッダーのみを比較します。
    OR file1.column56 = file2.column56 — 同じ場合はヘッダーのみを比較します。
    OR file1.column57 = file2.column57 ) —同じ場合は、ヘッダーのみを比較し、
    file1からfile3.csvを書き込みます。

必要な出力は次のようになります。 (file1形式と似ていますが、データは次のようにする必要があります)

Column1 Column55 column57, column58  column59  column60 column61, column62

ベストアンサー1

この試み、

awk -F ',' 'FNR==NR {a[$1]; next} $2 in a{print $2", "$8}' file1 file2 | sed 's/,.*\\/, /g'

123, ddd
124, uuu
221, vvv
333, xxx
  • -F '[\\\\,]'予想される出力に応じて、2つの区切り文字(カンマとバックスラッシュ)が必要です。バックスラッシュの動作を防ぐには、4つのバックスラッシュが必要です。

おすすめ記事