我有 2 个文件,每个文件包含如下内容:
文件1:
数据:[ 56, 34, 23, 54, 90, 234, 53, 12 ]
文件2:
数据:[ 42, 56, 23, 98, 90, 23, 53, 32 ]
我想将文件 1 中的第一个值与文件 2 中的第一个值相加,将第二个值与第二个值相加,依此类推。
所以 file3 应该是这样的:
数据:[ 98, 90, 46, 152, ... ]
我怎样才能实现这样的目标
答案1
awk -F ',? ' '
{
for(i=4;i!="]";i++)
A[i]=$i
getline file2
printf("%s %s %s ", $1, $2, $3)
i--
for(j=4;j<i;j++)
printf("%d, ", $j + A[j])
print $j + A[j++], $j
}
' file1
答案2
paste file1 file2 | tr '[],:' ' ' |
perl -lane '
my($b, $e) = grep { $F[$_] eq "data" } 0 .. $#F;
print
join $",
qw/data : [/,
join(", ", map { $F[$_] + $F[$_+$e-$b] } $b+1 .. $e-1),
q/]/,
;
' > file3
输出
data : [ 98, 90, 46, 152, 180, 257, 106, 44 ]
答案3
将 GNU awk 作为一行(为了便于阅读,这里分为两行):
$ awk 'BEGIN{FPAT="[0-9]+"}NR!=FNR{printf("%s","data : [ ")} \
{for (i=1;i<=NF;i++) if (NR==FNR) {a[i]=$i} else {printf("%s%s", (a[i]+$i), (i==NF)?" ]\n":",")}}' file5 file6
data : [ 98,90,46,152,180,257,106,44 ]
这使用 FPAT 方法而不是 FS 来定义字段。
FS 通常用于定义字段不包含哪些内容,而 FPAT 用于定义字段包含哪些内容。
File5 和 File6 包含您的输入数据:
$ cat file5
data : [ 56, 34, 23, 54, 90, 234, 53, 12 ]
$ cat file6
data : [ 42, 56, 23, 98, 90, 23, 53, 32 ]
答案4
$ awk -F'[^0-9]+' '
# output prefix
BEGIN {
printf "data : [ "
}
# read first file
NR == FNR {
for (i = 2; i < NF; i++) {
a[i] = $i
}
}
# read second file, output list of sums
NR != FNR {
for (i = 2; i < NF; i++) {
printf sep $i + a[i]
sep = ", "
}
}
# output suffix
END {
print " ]"
}
' file1 file2