NAME
Data::Search - Data structure search
SYNOPSIS
use Data::Search;
$data
= { ... };
@results
= datasearch(
data
=>
$data
,
search
=>
'values'
,
find
=>
qr/string/
,
return
=>
'hashcontainer'
);
DESCRIPTION
datasearch - Search data structures
This function allows you to search arbitrarily large/complex data structures for particular elements. You can search hash keys, or hash/array values, for a number/string or regular expression. The datasearch function can return either the found hash keys, the found values (which could be data structures themselves) or the container of the key or value (which is always going to be a data structure)
By default, hash keys are searched, and the corresponding values are returned. To search hash or array values, specify SEARCH => 'values'. To search both values and keys, specify SEARCH => 'all'.
To find an exact match of a string, set FIND => 'string'. To use a regular expression use the qr operator: FIND => qr/^name.*/i FIND may also be a 2 element array, to search for a key-value pair.
To return the hash keys found (or the hash keys corresponding to searched values), specify RETURN => 'keys'. To return both keys and values specify RETURN => 'all'.
You can also return the data structure containing the found key/value.
To do that, specify RETURN => 'container'. This will return the immediate container, either a hash or an array reference. You can also choose to get the closest hash container (even if the value was inside an array) by specifying RETURN => 'hashcontainer'.
Similarly, you can return the closest array container (even though the value found was a hash value or hash key) by specifying RETURN => 'arraycontainer'
Also, you can get an outer container by doing RETURN => 'container:xyz' in which case the container returned would be a structure pointed to by key xyz (if found to contain the search element somewhere inside it). Please see the examples at the end of this document.
ARGUMENTS The following arguments are accepted (case-insensitively). The only mandatory arguments are DATA and FIND.
data
=> Reference of structure to search
search
=> What elements to search:
keys
|
values
|all (
default
:
keys
)
find
=> Look
for
: string |
qr/regex/
| [
key
=> value ]
return
=> What to
return
:
keys
|
values
|all|
container|hashcontainer|arraycontainer|container:key_name
RETURN VALUES
Returns a list of matching elements (could be strings or references to internal parts (hashes/arrays) of the data structure.
EXAMPLES
my
@results
= datasearch(
data
=>
$ref
,
find
=>
'name'
);
That will
return
all
values
pointed to by hash
keys
called
'name'
my
@results
= datasearch(
data
=>
$ref
,
search
=>
'values'
,
find
=>
qr/alex/
i,
return
=>
'key'
);
That will
return
all
keys
that point to strings that match
"alex"
case insensitively.
my
@results
= datasearch(
data
=>
$ref
,
search
=>
'keys'
,
find
=>
qr/_id$/
,
return
=>
'all'
);
pointed to by those
keys
.
my
@results
= datasearch(
data
=>
$ref
,
return
=>
'container:myrecord'
,
find
=> [
suffix
=>
'Jr'
] )
That implies
search
=>
'all'
, searches
for
a key
'suffix'
that
has
value
'Jr'
, and returns any matching hashes pointed to by a key
named myrecord (even
if
suffix is deep inside those hashes)