![한 파일의 일치하는 문자열을 다른 파일의 일치하는 문자열로 바꾸는 방법은 무엇입니까?](https://rvso.com/image/170255/%ED%95%9C%20%ED%8C%8C%EC%9D%BC%EC%9D%98%20%EC%9D%BC%EC%B9%98%ED%95%98%EB%8A%94%20%EB%AC%B8%EC%9E%90%EC%97%B4%EC%9D%84%20%EB%8B%A4%EB%A5%B8%20%ED%8C%8C%EC%9D%BC%EC%9D%98%20%EC%9D%BC%EC%B9%98%ED%95%98%EB%8A%94%20%EB%AC%B8%EC%9E%90%EC%97%B4%EB%A1%9C%20%EB%B0%94%EA%BE%B8%EB%8A%94%20%EB%B0%A9%EB%B2%95%EC%9D%80%20%EB%AC%B4%EC%97%87%EC%9E%85%EB%8B%88%EA%B9%8C%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의 두 번째 열의 행이 cleandata.map의 두 번째 열의 행과 일치하는 경우 cleandata.map의 두 번째 및 네 번째 열의 행을lifted.map의 네 번째 열 값으로 바꿉니다.
답변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