sonicbill11 has asked for the wisdom of the Perl Monks concerning the following question:
I need to merge (or is it join?) two data sets by the id field for both data. These are fictional data sets for example.
Data set 1:
id x1 x2
A 12 45
A 10 12
A 15 74
C 11 41
C 18 12
B 23 15
D 19 10
D 11 12
E 14 5
E 34 31
F 10 45
Data set 2:
id word
A hello
B goodbye
D happy
E black
C blue
I want to keep all the data is Data 1, as long as it matches with Data 2, by id.
Desired output
A 12 45 hello
A 10 12 hello
A 15 74 hello
C 11 41 blue
C 18 12 blue
B 23 15 goodbye
D 19 10 happy
D 11 12 happy
E 14 5 black
E 34 31 black
my %file1hash; open (DAT1,"$fin1"); while(my $line=<DAT1>) { chomp($line); my ($id,$x1,$x2)=split(' ' ,$line); $file1hash{$id} = "$x1 $x2"; } close DAT1; open (DAT2,"$fin2"); while (my $line=<DAT2>) { chomp($line); my ($id,$word)=split(' ', $line); if (exists $file1hash{$id}) { printf ("%1s %5s %7s\n", $id, $file1hash{$id}, $word); } } close DAT2; exit;
My output from this code is
A 15 74 hello
B 23 15 goodbye
D 11 12 happy
E 34 31 black
C 18 12 blue
Almost there, but it only takes the last values for each id. Any help or direction to a previously asked similar question would be appreciated. Thanks!
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: Merging two data sets
by kevbot (Vicar) on Jun 13, 2014 at 05:32 UTC | |
by sonicbill11 (Initiate) on Jun 13, 2014 at 13:09 UTC | |
|
Re: Merging two data sets
by LanX (Saint) on Jun 13, 2014 at 01:37 UTC | |
|
Re: Merging two data sets
by vinoth.ree (Monsignor) on Jun 13, 2014 at 03:39 UTC | |
|
Re: Merging two data sets
by Jim (Curate) on Jun 13, 2014 at 05:06 UTC | |
|
Re: Merging two data sets
by InfiniteSilence (Curate) on Jun 13, 2014 at 20:28 UTC |