Beefy Boxes and Bandwidth Generously Provided by pair Networks
Don't ask to ask, just ask

(ar0n) Re: Faster Flat File

by ar0n (Priest)
on Feb 03, 2002 at 04:39 UTC ( #143022=note: print w/replies, xml ) Need Help??

in reply to Faster Flat File

I'd probably try something like this (untested):
#!/usr/bin/perl -w use strict; use IO::File; use Text::CSV_XS; { my $fh = new IO::File ("<$path/$database") or die "Can't open file: $!\n"; my $csv = new Text::CSV_XS ({ sep_char => '|' }); while ( my ($a,$b,$c,$d,$e,$f) = @{$csv->getline($fh)} ) { if ( -1 != index($s, $d) && -1 != index($r, $e) && -1 != index($m, + $f) ){ print "$b\n"; if ($c eq "Y"){ print "$a - tal\n"; } elsif ($p eq "Y"){ print "$e"; } } } }

I used index, since it's faster than a regex, generally, and you seemed to be simply searching for a substring, not an actual regex. Also, Text::CSV_XS is XS (compiled C) which is usually quite fast (faster than Perl, at any rate).

Update: As merlyn pointed out recently, index need not be faster than a regex (thanks for pointing that out, blakem).

[ ar0n -- want job (boston) ]

Log In?

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://143022]
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others about the Monastery: (2)
As of 2021-10-23 20:11 GMT
Find Nodes?
    Voting Booth?
    My first memorable Perl project was:

    Results (88 votes). Check out past polls.