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

perl实现多行模式匹配

发布时间:2020-12-15 23:58:15 所属栏目:大数据 来源:网络整理
导读:因为 grep不能匹配换行符 , grep只能单行匹配字符串,但是可以通过-A等选项打印上下文环境;sed在读入一行的时候会自动去掉末尾的换行,所以sed在进行多行匹配的时候很复杂。这里使用perl,先把文件的全部内容读入,然后进行多行匹配。代码如下: my $log_na

因为grep不能匹配换行符grep只能单行匹配字符串,但是可以通过-A等选项打印上下文环境;sed在读入一行的时候会自动去掉末尾的换行,所以sed在进行多行匹配的时候很复杂。这里使用perl,先把文件的全部内容读入,然后进行多行匹配。代码如下:


my $log_name = $ARGV[0];
open(FILE,"$log_name") or die "can't open $file $!n";
my $content = join("",<FILE>);
while($content =~ /<data>.*</data>n<user>hongchangfirst</user>n<msg><![ZHC]></msg>n/g)
{
? ? print $&,"n";
}
close(FILE);


这就可以把所有匹配的行都打印出来。

原文:http://www.voidcn.com/article/p-wcxhflsr-baq.html

作者:hongchangfirst

hongchangfirst的主页:http://blog.csdn.net/hongchangfirst

(编辑:李大同)

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

    推荐文章
      热点阅读