This is more than what you asked about, but there are two regexs in the following:
chop (%key_hash = map { split /\s*[|]\s*/,$_,2 } grep (!/^$/,<KEY_FH>) +); ^ ^ ^ ^ ^ ^ ^ ^ | | | | | | | | | | | | | | | + - F +ile handle | | | | | | + - Let only + non-empty file lines pass | | | | | + - Split string into two + parts | | | | + - Default scalar containi +ng a file line | | | + - Zero or more whitespaces | | + - Vertical bar as only member in +character set | + - Zero or more whitespaces + - Should be 'chomp' to remove the trailing newlines
It appears that this code splits a "|" delimited file line into two parts: the first field is the key and the remaining fields are the value. We can give it a try like this:
use strict; use warnings; use Data::Dumper; chomp (my %key_hash = map { split /\s*[|]\s*/,$_,2 } grep (!/^$/,<DATA +>)); print Dumper \%key_hash; __DATA__ AAA|B|C|D|E BBB|G|H|I|J CCC|1|2|3|4 DDD|6|7|8|9
The output shows the hash's key/value pairs:
$VAR1 = { 'CCC' => '1|2|3|4', 'BBB' => 'G|H|I|J', 'DDD' => '6|7|8|9', 'AAA' => 'B|C|D|E' };
Hope this helps!
In reply to Re: Regular expression
by Kenosis
in thread Regular expression
by Anonymous Monk
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |