in reply to Merging multiple JSON files into one using JSON::XS

G'day walkingthecow,

You were almost there. I suspect the unnecessary @fields is possibly what threw you (as that does seem to have complicated the code somewhat). To achieve what you want, change all of this:

my @fields; my $uuts = {}; while(<$fh>) { chomp; next if !-e "/tmp/files/$_.json"; my $decoded = decode_json( read_file("/tmp/files/$_.json") ); push @fields, $decoded; } $uuts->{People} = [ @fields ];

to just this:

my $uuts; while (<$fh>) { chomp; next if ! -e "/tmp/files/$_.json"; push @{$uuts->{People}}, @{decode_json(read_file("/tmp/files/$_.js +on"))}; }

I'm not really in a position to test that; however, here's a small test that shows the technique involved:

$ perl -Mstrict -Mwarnings -le ' use Data::Dumper; my @jsons = ([{a=>1}, {b=>2}], [{c=>3}, {d=>4}]); my $combo; for (@jsons) { print Dumper $_; push @{$combo->{People}} => @$_; } print Dumper $combo; ' $VAR1 = [ { 'a' => 1 }, { 'b' => 2 } ]; $VAR1 = [ { 'c' => 3 }, { 'd' => 4 } ]; $VAR1 = { 'People' => [ { 'a' => 1 }, { 'b' => 2 }, { 'c' => 3 }, { 'd' => 4 } ] };

-- Ken

Replies are listed 'Best First'.
Re^2: Merging multiple JSON files into one using JSON::XS
by walkingthecow (Friar) on Aug 12, 2013 at 12:56 UTC
    I tested it and it works perfectly! Thank you. I had solved the issue by not printing pretty (i.e., printing one big line), and doing some replacing. Your solution is much, much better than what I had.