我的档案是这样的:
0.35 0.45 0.25 0.44 0.35
0.06 0.10 0.14 0.15 0.00我想在每一行下面加上每一项价值的补充比例,即:
0.35 0.45 0.25 0.44 0.35
0.65 0.55 0.75 0.56 0.65
0.06 0.10 0.14 0.15 0.00
0.94 0.90 0.86 0.85 1.00到目前为止,我只在每一行下面插入了一个字符串:
typeset TMP_FILE=$( mktemp )
touch "${TMP_FILE}"
cp -p proportions_file "${TMP_FILE}"
sed -e 's/$/\nstring after each line/' "${TMP_FILE}" > proportions_file_final其中proportions_file是原始文件,proportions_file_final是输出:
0.35 0.45 0.25 0.44 0.35
string after each line
0.06 0.10 0.14 0.15 0.00
string after each line是否有一个函数可以用来代替“每一行后的字符串”来计算它上面的值的互补比例?
发布于 2016-12-15 11:39:10
您可以使用awk
awk 'function printdiff() {
for (i=1; i<n; i++)
printf "%.2f%s", (1-a[i]), (i<n-1?OFS:ORS)
}
NR > 1 {
printdiff()
}
{
for (n=1; n<=NF; n++)
a[n] = $n
}
1;
END {
printdiff()
}' file
0.35 0.45 0.25 0.44 0.35
0.65 0.55 0.75 0.56 0.65
0.06 0.10 0.14 0.15 0.00
0.94 0.90 0.86 0.85 1.00一行:
awk 'function printdiff(){for (i=1; i<n; i++) printf "%.2f%s", (1-a[i]), (i<n-1?OFS:ORS)} NR>1{printdiff()} {for (n=1; n<=NF; n++) a[n]=$n} 1; END{printdiff()}' filehttps://stackoverflow.com/questions/41163111
复制相似问题