foreach my $number(@transaction_numbers) { my $result =`command to get result`; print $result; while ($result =~ /transaction (\d+).*user:\s*(\S+)\s*#\s*(.*)/g) { my ($transaction, $user, $comment) = ($1, $2, $3); printf "%-12s %-10s %s\n", $1, $2, $3; } } #### transaction 1234567; promote; 2014/08/01 10:22:37 ; user: john # Performing a "promote" on file. /./abc/desf/test.pl 138699/1 (138700/1) transaction 4578643; promote; 2014/08/01 10:22:37 ; user: sam /./abc/desf/test.pl 138699/1 (138700/1) #### Transaction User Comments 1234567 john Performing a "promote" on file. #### Transaction User Comments 1234567 john Performing a "promote" on file. 4578643 sam