小编tes*_*234的帖子

使用正则表达式从Perl中提取纯文本的URL

如何使用Perl regexp从纯文本中提取具有特定扩展名的特定域(可能具有可变子域)的所有URL?我试过了:

my $stuff = 'omg http://fail-o-tron.com/bleh omg omg omg omg omg http://homepage.com/woot.gif dfgdfg http://shomepage.com/woot.gif aaa';
while($stuff =~ m/(http\:\/\/.*?homepage.com\/.*?\.gif)/gmsi)
{
print $1."\n";
}
Run Code Online (Sandbox Code Playgroud)

它失败了,给了我:

http://fail-o-tron.com/bleh omg omg omg omg omg http://homepage.com/woot.gif
http://shomepage.com/woot.gif
Run Code Online (Sandbox Code Playgroud)

我认为这不会发生因为我正在使用.*?,这应该是非贪婪的,并给我最小的匹配.谁能告诉我我做错了什么?(我不想要一些超级复杂的,预制的regexp来验证URL;我想知道我做错了什么,所以我可以从中学习.)

regex url perl

6
推荐指数
2
解决办法
1万
查看次数

标签 统计

perl ×1

regex ×1

url ×1