![あるファイル内の一致する文字列を別のファイル内の一致する文字列に置き換えるにはどうすればよいでしょうか?](https://rvso.com/image/170255/%E3%81%82%E3%82%8B%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E5%86%85%E3%81%AE%E4%B8%80%E8%87%B4%E3%81%99%E3%82%8B%E6%96%87%E5%AD%97%E5%88%97%E3%82%92%E5%88%A5%E3%81%AE%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E5%86%85%E3%81%AE%E4%B8%80%E8%87%B4%E3%81%99%E3%82%8B%E6%96%87%E5%AD%97%E5%88%97%E3%81%AB%E7%BD%AE%E3%81%8D%E6%8F%9B%E3%81%88%E3%82%8B%E3%81%AB%E3%81%AF%E3%81%A9%E3%81%86%E3%81%99%E3%82%8C%E3%81%B0%E3%82%88%E3%81%84%E3%81%A7%E3%81%97%E3%82%87%E3%81%86%E3%81%8B%3F.png)
次のようなファイルがあります:
head cleandata.map
1 1:775852:T:C 0 775852
1 1:1120590:A:C 0 1120590
1 1:1145994:T:C 0 1145994
1 1:1148494:A:G 0 1148494
...
そして別のファイル:
head lifted.map
1 1:775852:T:C 0.0 785989
1 1:1120590:A:C 0.0 1130727
1 1:1145994:T:C 0.0 1156131
1 1:1148494:A:G 0.0 1158631
...
私が取得したいのは、次のようになる cleandata.map を変更したものです。
1 1:785989:T:C 0 785989
1 1:1130727:A:C 0 1130727
1 1:1156131:T:C 0 1156131
1 1:1158631:A:G 0 1158631
...
したがって、lifted.map の 2 列目の行が cleandata.map の 2 列目の行と一致する場合は、cleandata.map の 2 列目と 4 列目の行を lifted.map の 4 列目の値に置き換えます。
答え1
試す
$ awk 'FNR==NR {T[$2] = $4; next} $2 in T {gsub ($4, T[$2])} 1' file2 file1
1 1:785989:T:C 0 785989
1 1:1130727:A:C 0 1130727
1 1:1156131:T:C 0 1156131
1 1:1158631:A:G 0 1158631