出力

出力

それぞれ次の内容を含む2つのファイルがあります。

ファイル1:

データ:[56、34、23、54、90、234、53、12]

ファイル2:

データ:[42、56、23、98、90、23、53、32]

ファイル1の最初の値をファイル2の最初の値に追加し、2番目の値を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を1行で表示します(ここでは読みやすくするために2行に分割します):

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

これは、FSの代わりにFPATメソッドを使用してフィールドを定義します。

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

関連情報