Bashで2つの異なるテキストファイルの2つの列を分割する方法

Bashで2つの異なるテキストファイルの2つの列を分割する方法

2つのテキストファイルがあり、各ファイルには数値列が含まれています。これらの2つの要素列をどのように分割し、新しい列を新しいテキストファイルに保存できますか?私はこれを試しましたが、成功しませんでした。

declare -a col1
declare -a col2
col1=`awk '{print $1}' File1.txt`
col2=`awk '{print $1}' File2.txt`
awk '{print $File1/$File2} > File3.txt

ベストアンサー1

除算が数学的除算を意味する場合は、次のことを試してください。

paste inf1 inf2 | awk '{print($1/$2)}'

inf1とはinf22つのファイルであるとします。一つ数値列(例:

$ seq 10 30 > inf1
$ seq  2 22 > inf2
$ paste inf1 inf2 | awk '{print($1/$2)}'
5
3.66667
3
2.6
2.33333
2.14286
2
1.88889
1.8
1.72727
1.66667
1.61538
1.57143
1.53333
1.5
1.47059
1.44444
1.42105
1.4
1.38095
1.36364

特定の形式が必要な場合は、代わりにprintfを使用してくださいprint

その場合〜しなければならないシェルで完了(bashコード、必要に応じて変換可能):

$ readarray -t a <inf1
$ readarray -t b <inf2
$ for ((i=0;i<${#a[@]};i++)); do
      printf '%8.4f\n' "$((10000000*a[i]/b[i]))e-7"
done
  5.0000
  3.6667
  3.0000
  2.6000
  2.3333
  2.1429
  2.0000
  1.8889
  1.8000
  1.7273
  1.6667
  1.6154
  1.5714
  1.5333
  1.5000
  1.4706
  1.4444
  1.4211
  1.4000
  1.3810
  1.3636

おすすめ記事