Crossposted question deserves a crossposted answer. Here's what I came up with:
#!/usr/bin/env perl use strict; use warnings; use Data::Dumper; use 5.14.0; my %stuff; #extract the header row. #use the regex to remove the linefeed, because #we can't chomp it inline like this. #works since perl 5.14 #otherwise we could just chomp (@header) later. my ( $id, @header ) = split( /\|/, <DATA> ); chomp (@header); while (<DATA>) { #turn this row into a hash of key-values. my %row; ( $id, @row{@header} ) = split(/\|/); #diag print print Dumper \%row; #iterate each key, and insert into $row. foreach my $key ( keys %row ) { push( @{ $stuff{$id}{$key} }, $row{$key} ); } } #diag print print Dumper \%stuff; foreach my $id ( sort keys %stuff ) { #join this record by '|'. print join('|', $id, #turn inner arrays into comma separated via map. map { my %seen; #use grep to remove dupes - e.g. "abc,abc" -> "abc" join( ",", grep !$seen{$_}++, @$_ ) } @{ $stuff{$id} }{@header} ), "\n"; } __DATA__ id|Name|app1|app2 1|abc|234|231| 2|xyz|123|215| 1|abc|265|321| 3|asd|213|235|

As a result it'll generate:

id|Name|app1|app2 1|abc|234,265|231,321 2|xyz|123|215 3|asd|213|235

Therefore handles arbitrary fields and arbitrary numbers of 'collisions' neatly.


In reply to Re: appending values based on criteria by Preceptor
in thread appending values based on criteria by logeshwaran

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.