Implementing Google
or AltaVista in Perl
for this kind of application is likely overkill, so here's
a simple solution.
my (@names) = ( ... );
sub search
{
my (@search_keywords) = split (/\s+/, shift);
my ($match_code) = "sub{".join('&&', map { "/\Q$_\E/" } @searc
+h_keywords)."}";
my ($match_func) = eval $match_code;
return grep { &$match_func() } (@names);
}
my (@results) = search ("the fried potato king");
This will return all records that match all terms.
For a version that matches any, switch the '&&'
in the join() to be '||' instead.
Essentially, this 'search' function generates a subroutine
that tells grep() if the array entry matches or not. You
can have a look at the value of $match_code to see what it
is doing.
The \Q and \E are used to escape the metacharacters which
would interfere with the // regexp. Saves you from having
to tr/// them yourself.
Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
Read Where should I post X? if you're not absolutely sure you're posting in the right place.
Please read these before you post! —
Posts may use any of the Perl Monks Approved HTML tags:
- a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
|
For: |
|
Use: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.
|
|