JOINから返された切り捨て結果

JOINから返された切り捨て結果

LinuxではJoinコマンドを使用しますが、結果はコンピュータによって異なります。 2つの単純なファイルがあります。

cat 1.txt  
a aaa,0.2
b bbb,0.3
c ccc,0.5

cat 2.txt
a aaa,0.2
b bbb,0.3
c ccc,0.6

次のコマンドを実行しています。

join -a 1 -1 1 -2 1 -t "," -o 1.1' '1.2' '2.2 <(cat 1.txt| sort -t ",") <(cat 2.txt| sort -t ",") 

マシン1の結果:

,0.2a,0.2
,0.3b,0.3
,0.6c,0.5

join --version
join (GNU coreutils) 8.13

locale
LANG=en_US.UTF-8
LANGUAGE=en_US.UTF-8
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=en_US.UTF-8

マシン2の結果:

a aaa,0.2,0.2
b bbb,0.3,0.3
c ccc,0.5,0.6

join --version
join (GNU coreutils) 5.97

locale
LANG=en_US.UTF-8
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=

明らかに、最初のコンピュータの結果は間違っていました。切りました。私は成功せずに別のロケールを使ってみました。

答え1

を使用してファイルを修復するdos2unixか、インストールされていない場合:

sed -i 's/\r$//' {1,2}.txt 

関連情報