regex – Perl遍历每个匹配

让我们说,我扫描一个页面的原始HTML寻找这个正则表达式。 (末尾的引号是故意的)。
m/(https?:\/\/.*?(?:'|"))/

这种模式可能匹配〜100次。什么是常见的perl惯用法/一种快速方法来迭代所有捕获组匹配的列表?

解决方法

perlretut(一个非常精细的教程)
while ($x =~ /(\w+)/g) {
        print "Word is $1,ends at position ",pos $x,"\n";
    }

你可以使用while和g修饰符迭代所有匹配,$ 1你获得捕获组1的内容在这个例子中,你也得到了pos的位置。

相关文章

1. 如何去重 #!/usr/bin/perl use strict; my %hash; while(...
最近写了一个perl脚本,实现的功能是将表格中其中两列的数据...
表的数据字典格式如下:如果手动写MySQL建表语句,确认麻烦,...
巡检类工作经常会出具日报,最近在原有日报的基础上又新增了...
在实际生产环境中,常常需要从后台日志中截取报文,报文的形...
最近写的一个perl程序,通过关键词匹配统计其出现的频率,让...