> I would ignore the case where the two keys are the same.
... because I doubt this will lead to any predictable results anyway (sorting matters).
use strict; use warnings; use Data::Dump qw/pp dd/; my $h_orig = { '/a/b/c/dt/data/SUSE/tool/0.9.0' => '/a/b/c/dt/tools/SUSE/tool/0.9.0 +', '/nfs/us/tools/SUSE12' => '/usr/bin', '/a/b/c' => '/p' }; my $pattern = join "|", map quotemeta, keys %$h_orig; my %copy = %$h_orig; s/^($pattern)/$h_orig->{$1}/g for values %copy; pp $h_orig, \%copy;
-*- mode: compilation; default-directory: "d:/tmp/pm/" -*- Compilation started at Sat Feb 5 21:29:56 C:/Strawberry/perl/bin\perl.exe -w d:/tmp/pm/replace_patl.pl ( { "/a/b/c" => "/p", "/a/b/c/dt/data/SUSE/tool/0.9.0" => "/a/b/c/dt/tools/SUSE/tool/0.9 +.0", "/nfs/us/tools/SUSE12" => "/usr/bin", }, { "/a/b/c" => "/p", "/a/b/c/dt/data/SUSE/tool/0.9.0" => "/p/dt/tools/SUSE/tool/0.9.0", "/nfs/us/tools/SUSE12" => "/usr/bin", }, ) Compilation finished at Sat Feb 5 21:29:57
Cheers Rolf
(addicted to the Perl Programming Language :)
Wikisyntax for the Monastery
In reply to Re: Replacing substrings with links
by LanX
in thread Replacing substrings with links
by ovedpo15
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |