Anyevent学习之一:Anyevent::HTTP

本文详细介绍了如何利用Perl语言中的AnyEvent::HTTP模块实现并行异步网页抓取,通过设置并发数、构建待查询关键词列表及定义回调函数,有效提升了数据获取效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这个是CU上斑竹提供的例子,

使用AnyEvent::HTTP模块并行异步抓取网页

写的确实结构很清晰,可以作为经典例子

#!/usr/bin/perl

use strict;
use warnings;
use AnyEvent;
use AnyEvent::HTTP;

my $cocurrent = 100;    # 并发数
my @todoList = map { "keyword" . $_ } (1 .. 1000); # 待查询的关键词

my $cv = AnyEvent->condvar;

doit() foreach 1..$cocurrent;

sub doit{
    my $word = shift @todoList;
    return if not defined $word;

    $cv->begin;
    http_get( "http://www.baidu.com/s?wd=$word", sub { done( $word, @_ ) } );
}

sub done {
    my ($word, $content, $hdr) = @_;

    $cv->end();
    print "Search: $word\tStatus: ", $hdr->{Status}, "\n";
    doit();
}

$cv->recv();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值