それぞれ次の内容を含む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