File1.txt
item1 carA
item2 carB
item3 carC
item4 platD
item5 carE
File2.txt
carA platA
carB platB
carC platC
carE platE
원하는 출력 :
item1 platA
item2 platB
item3 platC
item4 platD
item5 platE
어떻게하니?
답변
아래 답변은 SO 와 비슷한 Q & A를 기반으로하며 일부 관련 수정 사항이 있습니다.
$ awk 'FNR==NR {dict[$1]=$2; next} {$2=($2 in dict) ? dict[$2] : $2}1' file2.txt file1.txt
item1 platA
item2 platB
item3 platC
item4 platD
item5 platE
아이디어는 인덱스가있는 해시 맵을 만들고 사전으로 사용하는 것입니다.
두 번째 질문에 대해 귀하의 의견에 요청했습니다 ( 의 두 번째 열이 file1.txt
여섯 번째 열인 경우 어떻게 변경해야합니까 ).
입력 파일이 다음과 같은 경우 file1b.txt
:
item1 A5 B C D carA
item2 A4 1 2 3 carB
item3 A3 2 3 4 carC
item4 A2 4 5 6 platD
item5 A1 7 8 9 carE
다음 명령이이를 수행합니다.
$ awk 'FNR==NR {dict[$1]=$2; next} {$2=($6 in dict) ? dict[$6] : $6;$3="";$4="";$5="";$6=""}1' file2.txt file1b.txt
item1 platA
item2 platB
item3 platC
item4 platD
item5 platE
답변
나는 당신이 말했다는 것을 알고 awk
있지만, join
이 목적을위한 명령이 있습니다 …
{
join -o 1.1,2.2 -1 2 -2 1 <(sort -k 2 File1.txt) <(sort -k 1 File2.txt)
join -v 1 -o 1.1,1.2 -1 2 -2 1 <(sort -k 2 File1.txt) <(sort -k 1 File2.txt)
} | sort -k 1
join
이 행이 아닌 경우 첫 번째 명령 으로 충분 합니다.
item4 platD
이 명령은 기본적으로 첫 번째 파일의 두 번째 열 ( -1 2
)과 두 번째 파일의 첫 번째 열 ( )을 기반으로 결합하고 첫 번째 파일 의 첫 번째 열과 두 번째 파일의 두 번째 열 ( -2 1
)을 출력합니다 -o 1.1,2.2
. 페어링 된 라인 만 표시됩니다. 두 번째 조인 명령은 거의 같은 내용이지만, 페어링 할 수없는 첫 번째 파일의 행 ()을 표시하고 첫 번째 파일 -v 1
의 첫 번째 열과 첫 번째 파일의 두 번째 열 ( )을 출력 한다고 합니다 -o 1.1,1.2
. 그런 다음 두 출력을 결합하여 정렬합니다. sort -k 1
첫 번째 열 sort -k 2
을 기준으로 정렬을 의미하고 두 번째 열 을 기준으로 정렬하는 것을 의미합니다. 파일을 전달하기 전에 결합 열을 기준으로 파일을 정렬하는 것이 중요합니다 join
.
이제 정렬을 두 번 작성했습니다. 도움이 될 수 있으면 디렉토리로 파일을 나누는 것을 좋아하지 않기 때문입니다. 그러나 데이비드 포스터 (David Foerster)가 말한 것처럼 파일의 크기에 따라 파일을 정렬 한 후 저장하여 두 번 정렬 할 때까지 기다리지 않을 수 있습니다. 크기에 대한 아이디어를주기 위해 다음은 내 컴퓨터에서 백만 줄과 천만 줄을 정렬하는 데 걸리는 시간입니다.
$ ruby -e '(1..1000000).each {|i| puts "item#{i} plat#{i}"}' | shuf > 1million.txt
$ ruby -e '(1..10000000).each {|i| puts "item#{i} plat#{i}"}' | shuf > 10million.txt
$ head 10million.txt
item530284 plat530284
item7946579 plat7946579
item1521735 plat1521735
item9762844 plat9762844
item2289811 plat2289811
item6878181 plat6878181
item7957075 plat7957075
item2527811 plat2527811
item5940907 plat5940907
item3289494 plat3289494
$ TIMEFORMAT=%E
$ time sort 1million.txt >/dev/null
1.547
$ time sort 10million.txt >/dev/null
19.187
백만 줄의 경우 1.5 초, 천만 줄의 경우 19 초입니다.