加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

perl – 如何制作WWW:机械化以不两次获取页面?

发布时间:2020-12-16 06:08:55 所属栏目:大数据 来源:网络整理
导读:我有一个用OO Perl编写的网络抓取应用程序.应用程序中使用了单个 WWW::Mechanize对象.如何使其不能两次获取相同的URL,即使用相同的URL no-op创建第二个get(): my $mech = WWW::Mechanize-new();my $url = 'http:://google.com';$mech-get( $url ); # first
我有一个用OO Perl编写的网络抓取应用程序.应用程序中使用了单个 WWW::Mechanize对象.如何使其不能两次获取相同的URL,即使用相同的URL no-op创建第二个get():

my $mech = WWW::Mechanize->new();
my $url = 'http:://google.com';

$mech->get( $url ); # first time,fetch
$mech->get( $url ); # same url,do nothing

解决方法

您可以继承WWW :: Mechanize并重新定义get()方法以执行您想要的操作:

package MyMech;
use base 'WWW::Mechanize';

sub get {
    my $self = shift;
    my($url) = @_;

    if (defined $self->res && $self->res->request->uri ne $url) {
        return $self->SUPER::get(@_)
    }
    return $self->res;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读