输出

输出

我有 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

相关内容