in reply to ...How to parse search engine results fast?
#! /usr/bin/perl -w use strict; use warnings; use LWP; use threads; use Thread::Queue; my $query ="perl"; my $dataQueue = Thread::Queue->new; my $threadCount = 0; while (<DATA>) { chomp; s/^\s+//; s/\s+$//; my ($engine, $url) = split /\s+/; next unless $url; $url.=$query; print "$url\n"; my $thr = threads->new(\&doSearch, $engine, $url); $thr->detach; $threadCount ++; } while ($threadCount) { my $engine = $dataQueue->dequeue; my $content = $dataQueue->dequeue; print "$engine returned: $content\n"; $threadCount --; } print "Parse and return remaining content\n"; sub doSearch { my $engine = shift; my $url = shift; my $ua = LWP::UserAgent->new; $ua->agent('Mozilla/5.0'); $ua->timeout(10); $ua->env_proxy; my $response = $ua->get($url); if ($response->is_success) { $dataQueue->enqueue($engine, $response->content); } else { $dataQueue->enqueue($engine, $response->message); } } __DATA__ Google http://www.google.com/search?q= Yahoo! http://search.yahoo.com/search?p= MSN http://beta.search.msn.co.uk/results.aspx?q=
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^2: ...How to parse search engine results fast?
by A200560 (Novice) on Feb 03, 2005 at 18:13 UTC | |
|
Re^2: ...How to parse search engine results fast?
by tphyahoo (Vicar) on Mar 03, 2005 at 16:46 UTC | |
|
Re^2: ...How to parse search engine results fast?
by A200560 (Novice) on Jan 11, 2006 at 16:43 UTC |