如何在bash中从两个不同的文本文件中划分两列

如何在bash中从两个不同的文本文件中划分两列

我有两个文本文件,每个文件都包含一列数字。如何将这两列元素虎钳分开并将新列保存在新的文本文件中?我尝试过这个,但没有成功。

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)}'

假设inf1inf2是两个文件数字列,例如:

$ 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.

如果它必须在 shell 中完成(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

答案2

dc 是完成这项工作的好工具:

dc -f File1.txt -f File2.txt -e '5kzdsa2/sb[la:zla1-dsa0<m]smlmx[la1+ddsa;zrlb+;z/pclbla<n]snlnx' > File3.txt

并附评论:

dc -f File1.txt -f File2.txt -e '
# set the precision
5k
# keep the number of item in register a and the half in register b
z d sa 2 / sb
# populate indexed register z from z[1] to z[number of item]
[la :z la 1 - d sa 0  <m]sm lmx
# get 2 items from register z and divide them 
[ la 1 + d d sa ;z r lb + ;z / p c lb la <n ]sn lnx' > File3.txt

相关内容