Perl 爬取内容失败

2014-07-01 00:07:54 +08:00
 akagi
使用的是 Mojo::UserAgent, 用来爬取某网站的用户回答列表,但是爬取时会随机在某网页停止,显示

"Can't call method "all_text" on an undefined value at core.pl line 188."

实现如下,

sub get_keyword_list {
my ($ua, @list, $keyword) = @_;

foreach my $l (@list) {
my $tx = $ua->get($l->[0]);
say $l->[0];
# what should it be?
my $answer = $tx->res->dom->at('div.zm-editable-content.clearfix')->all_text;
my $timestamp = $tx->res->dom->at('a.answer-date-link.meta-item')->text;
open my ($tmp), '>>', 'tmp.txt' or die;
say $tmp $answer;
say $tmp $timestamp;
}
}

其中 $l->[0] 取到列表中各网页 url, 类似如下形式: http://www.zhihu.com/question/20304733/answer/25775012

为什么会出现错误,无法理解ing, 求解。
7706 次点击
所在节点    Perl
8 条回复
forbe
2014-07-01 00:29:37 +08:00
用 Go吧,http://meijia0.com就是我最近用GO写的一个小爬虫,很简单很方便
11138
2014-07-01 06:07:07 +08:00
先判断一下“get”成功了再往下操作。
orzfly
2014-07-01 07:47:32 +08:00
用来爬取某网站
类似如下形式: http://www.zhihu.com
akagi
2014-07-01 09:59:40 +08:00
@11138 出错的原因是什么呢?
11138
2014-07-01 10:44:18 +08:00
my $tx = $ua->get($l->[0]);

这里,由于各种网络原因,“get”的结果可能是失败的,所以你要判断一下啊。

http://search.cpan.org/~sri/Mojolicious-5.10/lib/Mojo/UserAgent.pm

if (my $res = $tx->success) { say $res->body }
else {
my $err = $tx->error;
die "$err->{code} response: $err->{message}" if $err->{code};
die "Connection error: $err->{message}";
}
akagi
2014-07-01 11:07:10 +08:00
@11138 恩,我表述的不大清楚。之前你的回复我看明白了,只是还没搞懂get失败的可能原因。如果单次get可以成功,多条情况可能失败,这里的“各种网络原因”,具体可能有哪些,希望能稍微展开下 :)
11138
2014-07-01 11:16:11 +08:00
如果获取失败你可以将错误的信息打印出来看看啊,参考上面的代码。
akagi
2014-07-01 11:23:31 +08:00
@11138 嗯,谢谢。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/120329

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX