0

我想循环浏览网页上的所有链接,所以我试过了

#!/usr/bin/perl

use WWW::Mechanize;

my $url = "http://www.google.com";
my $m = WWW::Mechanize->new();
$m->get($url);

my @links = $m->find_all_links(url_regex => qr/google/);

foreach my $link (@links){
    print Dumper $m->get($link->url_abs);
}     

这给了我例如

$VAR11 = bless( [
                  'http://www.google.com/ncr',
                  'Google.com in English',
                  undef,
                  'a',
                  $VAR1->[4],
                  {
                    'href' => 'http://www.google.com/ncr',
                    'class' => 'gl nobr'
                  }
                ], 'WWW::Mechanize::Link' );

问题

如何只输出链接?

4

1 回答 1

6

文档指出链接作为WWW::Mechanize::Link对象返回。所以:

my @links = $m->find_all_links(url_regex => qr/google/);
print $_->url, "\n" for @links;
于 2012-05-01T15:57:02.327 回答