Core Function Grep

From Sputnik Wiki
Jump to: navigation, search
Grep( <array>, <pattern>, <flag> )

Contents

Description

Returns a new array consisting of the elements of the input arrays values that match the given regex pattern.

Parameters

array

The array to use.

pattern

A regular expression pattern to use.

OR

An array of regular expression patterns to use.

flag

Optional; If the flag is higher than 0 the search will be inverted and everything that does not match will be returned instead of everything that does match. (Default is 0)

Return Value

Success - Returns new array with information.

Failure - Returns empty array.

Remarks

This also includes Hash values with the array values.

Example

Return everything that matches

my $array = array( "Test123", "moo", "cat", "dog555", "meows"  );
my $lol = Grep( $array, m/\d+/ );
foreach($lol as $c)
{
	println("Value: $c");
}

Return everything that does not match (by setting the flag to 1)

my $array = array( "Test123", "moo", "cat", "dog555", "meows"  );
my $lol = Grep( $array, m/\d+/, 1 );
foreach($lol as $c)
{
	println("Value: $c");
}

Using an array of patterns

my $array = array( "Test123", "moo", "cat", "dog555", "meows", "hehe?s"  );
my $lol = Grep( $array, array(m/\d+/, m/\?/) );
foreach($lol as $c)
{
	println("Value: $c");
}

In this example it returns all KEYS that match in the Hash(Dictionary) instead of the values

my $array = array( "One" => "Cat", "Two222" => "Fire", "Three" => "FoX", "Four444" => "Water" );
my $lol = _GrepKeys( $array, m/\d+/ );
foreach($lol as $key <=> $value)
{
	println("$key <=> $value");
}
 
// A custom made reverse Grep for returning matching kesy instead of matching values
Function _GrepKeys( $input, $pattern, $flags = 0 )
{
	my $keys = Grep( Keys($input), $pattern, $flags );
	my $vals = array();
	foreach ( $keys as $key )
		$vals[$key] = $input[$key];
	return $vals;
}
Personal tools
Namespaces
Variants
Actions
Navigation
Toolbox