суммирование двух матриц, каждый из которых в другом файле

У меня есть 2 файла, каждый из которых содержит следующее:

файл 1:

данные: [56, 34, 23, 54, 90, 234, 53, 12]

файл 2:

данные: [42, 56, 23, 98, 90, 23, 53, 32]

Я хочу суммировать первое значение из файла 1 с 1-м значением из файла 2 и 2-го со вторым и т. д. и т. д.

поэтому файл3 должен выглядеть следующим образом:

данные: [98, 90, 46, 152, …]

как я могу достичь чего-то подобного

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

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