使用AWK从两个文件中构造n个列

Shu*_*mon 5 linux bash perl awk gawk

我有两个N列数的文件

文件1:

A   1   2    3  .......  Na1
B   2   3    4  .......  Nb1
Run Code Online (Sandbox Code Playgroud)

文件2:

A   2   2    4  .......  Na2
B   1   3    4  .......  Nb2
Run Code Online (Sandbox Code Playgroud)

我想要一个输出,其中File1的第一列值将从File2的第一列中减去,这样直到N列,如下所示:

A  -1   0    -1  ........ (Na1-Na2)
B   1   0     0  ........ (Nb1-Nb2)
Run Code Online (Sandbox Code Playgroud)

如何做到这一点是在Linux环境下的AWK或Perl脚本?

per*_*eal 1

像这样的东西:

use strict;
use warnings;

my (@fh, @v);
for (@ARGV) {
  open (my $handle, "<", $_) or die ("$!: $_");
  push @fh, $handle;
}
while (@v = map { [split ' ', <$_> ] } @fh and defined shift @{$v[0]}) {
  print join(" ", (shift @{$v[1]}, map { $_ - shift(@{$v[1]}) } @{$v[0]})), "\n";
}
close $_ for (@fh);
Run Code Online (Sandbox Code Playgroud)

跑步:

 perl script.pl input1 input2
Run Code Online (Sandbox Code Playgroud)