in reply to Re^2: Converting Excel to Hash
in thread Converting Excel to Hash

A hash cannot have multiple values for the same key. You will need to rethink your data structure.

Consider storing array references as values instead of hash references as values:

{ '1'=> [{ 'clz=>'nit' 'degree'=>'ph.d', 'name'=>'teja' }, { 'clz=>'iit' 'degree'=>'M.tech', 'name'=>'teja' }],####This block not coming in output '2'=>[{ 'clz=>'mit' 'degree'=>'ravi', 'name'=>'B.Tech' }] };

This change will also need changes in your code on how you fill the data structure and how you output your data structure.

Replies are listed 'Best First'.
Re^4: Converting Excel to Hash
by ravi179 (Novice) on Jan 03, 2017 at 15:20 UTC

    I am new to perl. Could you please guide me how to achieve that.Thanks in advance.

      See perlintro and perldsc maybe.

      The idea is to initialize $data{ $master_key } with an empty array for each id and then to push every found element onto that array:

      ... $data{$master_key} ||= []; # if we haven't seen $master_key yet, creat +e a fresh array my %this_set; for my $col(1 .. $eSheet->{MaxCol}) { # Some logging for debugging if( !defined $eSheet->{Cells}[$row][$col]) { print "Row $row: skipping empty column $col\n"; next; }; my $key= $eSheet->{Cells}[0][$col]->Value; my $value = $eSheet->{Cells}[$row][$col]->Value; $this_set{$key}=$value; } } # Store our found set for that ID: push @{ $data{ $master_key }}, \%this_set;
        use Spreadsheet::ParseExcel; use Data::Dumper; $filename="Book2.xls"; $e=new Spreadsheet::ParseExcel; $eBook=$e->Parse($filename); $sheets = $eBook->{SheetCount}; ($eSheet, $sheetName); foreach $sheet (0 .. $sheets - 1) { $eSheet = $eBook->{Worksheet}[$sheet]; $sheetName = $eSheet->{Name}; print "Worksheet $sheet: $sheetName\n"; %set =(); %data =(); foreach $row( 1 .. $eSheet->{MaxRow} ) { $master_key= ($eSheet->{Cells}[$row][0]->Value); foreach $col(1 .. $eSheet->{MaxCol}) { next unless defined $eSheet->{Cells}[$row][$col]; my $key=$eSheet->{Cells}[0][$col]->Value; my $val=($eSheet->{Cells}[$row][$col]->Value); $set{$key}=$val; } } push @{ $data{$master_key}}, \%set; print Dumper %data; }
        $var1='2'; $var2=[{ clz=>iir, degreee=>b.tech, name=>ravi, } ];

        only last row is coming

        .

      Where the spreadsheet is missing a master-key are you assuming the previous value ?

      ID NAME Degree Collage 1 Teja B.Tech NIT M.Tech IIT(the problem is in converting this line) 2 Ravi B.tech MIT
      poj

        yes.Could you help me in this