我只是厭倦了使用join
命令而沒有獲得所需的結果,並且它返回了一些錯誤。在第二個字段加入未排序的文件
我還讀過所有與join
命令相關的所有查詢,並且在SuperUser中也有,但無法獲得成功。
如何使用join
或awk
?
file1.csv
autoid|Mycolumn
5|Odhav, Gujarat, 380010
7|Navrangpura, Gujarat, 380009
16|Kalupur, Gujarat, 380002
32|Naroda, Gujarat, 380025
62|Khamasa, Gujarat, 380001
73|Sola Road, Gujarat, 380063
74|Railwaypura, Gujarat, 380002
78|Meghaninagar, Gujarat, 380016
85|Thaltej, Gujarat, 380054
file2.csv
5|Odhav, Gujarat, 380010|22.406347|73.824345
7|Navrangpura, Gujarat, 380009|22.328403|73.881841
16|Kalupur, Gujarat, 380002|22.379901|73.814217
32|Naroda, Gujarat, 380025|22.417059|73.887806
38|Raikhad, Gujarat, 380001|22.491544|73.782878
39|Ashram Road, Gujarat, 380006|22.279248|73.846393
44|Raipur, Gujarat, 380002|22.346186|73.87462
56|Jamalpur, Gujarat, 380022|22.518504|73.785024
58|Patharkuva, Gujarat, 380001|22.308473|73.825071
62|Khamasa, Gujarat, 380001|22.100711|73.707207
73|Sola Road, Gujarat, 380063|22.026236|73.732926
74|Railwaypura, Gujarat, 380002|21.992994|73.86893
78|Meghaninagar, Gujarat, 380016|21.955106|73.878629
85|Thaltej, Gujarat, 380054|21.989253|73.735725
我使用這個命令,但是無法得到期望的結果:
$ join -t'|' -1 2 -2 2 <(sort -k2 Areaprob.csv) <(sort -k2 Com_remoteArea.csv)>output.csv
它返回這樣的事情;正如你所看到的,我已經使用sort
命令和上面給出的join
。
join: file 1 is not in sorted order
join: file 2 is not in sorted order
我output.csv
看起來是這樣的 - 它不返回所有9條爲file1.csv
Mycolumn|autoid|autoid|Gis_lat|Gis_long
Khamasa, Gujarat, 380001|62|62|22.100711|73.707207
Railwaypura, Gujarat, 380002|74|74|21.992994|73.86893
Thaltej, Gujarat, 380054|85|85|21.989253|73.735725
Sola Road, Gujarat, 380063|73|73|22.026236|73.732926
嘿感謝它。你能向我解釋它是如何工作的!! – user1586957 2013-03-21 04:28:35
@ user1586957它首先將file1的第一列保存到數組中,然後對於file2的每一行,檢查該數組中的第一列是否爲true。 – Kent 2013-03-21 09:39:17