我有两个文本文件,每个文件都包含一列数字。如何将这两列元素虎钳分开并将新列保存在新的文本文件中?我尝试过这个,但没有成功。
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
和inf2
是两个文件一数字列,例如:
$ 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