qod*_*nja 0 string parameters perl explode
我有一个字符串
"myhashkey?key1=val1&key2=val2&key3=val3&key4=val4"
Run Code Online (Sandbox Code Playgroud)
我想要爆炸
myhashkey => {
key1 => val1,
key2 => val2,
key3 => val3
}
Run Code Online (Sandbox Code Playgroud)
我也想把它折回到同一个字符串.
到目前为止,我提出的相当混乱,使用索引并尝试手动构建值
$arg = $_[0];
#if arg has = it may be key=val string
if(index($arg,'=') > -1 ){
#if arg has & character it might be key=val&key1=val
if(index($arg,'&') > -1 ){
#$arg =~ m/[=&\?]/
@r = split(/[=&\?]/,$arg);
my $hashkey = shift(@r)
my %values = @r;
return $class->$orig( key => $k, $value => \%values );
...
}else{
@r = split('=',$arg);
return ( key => $r[0], $value => $r[1] );
}
}
Run Code Online (Sandbox Code Playgroud)
我不知道index(),split()和join()函数与其他实现此功能的方法相比有多昂贵.我想也许我可以使用map + grep,但我不确定如何为grep创建rergex.
我也不想重新发明轮子,所以希望有人能更好地了解如何做到这一点.
更新 BTW这是发生在穆斯BUILDARGS子,所以我不希望像使用URI模块以每次解析字符串.
这就是我在BUILDARGS中使用该功能的方法
my $w = My::Param->new( 'hashkey?key1=val1&key2=val2&key3=val3');
my $x = My::Param->new( key => 'x', value => '7' );
my $y = My::Param->new( 'y=123' );
Run Code Online (Sandbox Code Playgroud)
在印刷翻斗车上生产这个(*)
{ 'key1' => 'val1', 'key2' => 'val2', 'key3' => 'val3' }
bless( { 'key' => 'hashkey', 'meta_info' => [ #0 'hashkey?key1=val1&key2=val2&key3=val3' ], 'value' => { 'key1' => 'val1', 'key2' => 'val2', 'key3' => 'val3' } }, 'My::Param' )
bless( { 'key' => 'x', 'meta_info' => [ #0 'key', #1 'x', #2 'value', #3 '7' ], 'value' => '7' }, 'My::Param' )
bless( { 'key' => 'y', 'meta_info' => [ #0 'y=123' ], 'value' => '123' }, 'My:Param' )
Run Code Online (Sandbox Code Playgroud)
pil*_*row 10
在这种情况下,已经发明的轮子被命名为URI
$ perl -MData::Dumper -MURI -e'
$uri = URI->new("myhashkey?key1=val1&key2=val2&key3=val3&key4=val4");
$h{ $uri->path } = { $uri->query_form };
print Dumper(\%h);
'
Run Code Online (Sandbox Code Playgroud)