免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3375 | 回复: 10
打印 上一主题 下一主题

per 中模式匹配 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-12-20 15:11 |只看该作者 |倒序浏览
10可用积分
LOG日志文件格式如下:
PART。1
****************
PART。2
****************
PART。3
****************
PART。4
****************
END JOB

我读取的log日志文件如上文,这个文件大概有10M左右,但是文件相对来说比较有规律,PART。1到END JOB。
我打的星号是此文件中的一部分内容。
我现在只想要PART。3中的一部分数据。请问在读取文件时,如何快速定位到以下部分内容:
PART。3
****************
PART。4

论坛徽章:
0
2 [报告]
发表于 2009-12-20 15:18 |只看该作者
if(/PART。3/../PART。4/) {
   do sth...
}

论坛徽章:
1
狮子座
日期:2013-12-16 16:09:24
3 [报告]
发表于 2009-12-20 15:34 |只看该作者
哎,晚来了一步。。。

论坛徽章:
0
4 [报告]
发表于 2009-12-20 15:38 |只看该作者

回复 #2 dugu072_cu 的帖子

好,我试试。

论坛徽章:
0
5 [报告]
发表于 2009-12-20 16:12 |只看该作者

回复 #2 dugu072_cu 的帖子

哈哈,谢谢楼上的,我之前都按行去匹配的,花了不少时间,这样真是太快了。

论坛徽章:
0
6 [报告]
发表于 2009-12-20 16:13 |只看该作者

回复 #2 dugu072_cu 的帖子

不知道还有其它方法没有?

论坛徽章:
0
7 [报告]
发表于 2009-12-20 16:37 |只看该作者
yes, range operator

论坛徽章:
0
8 [报告]
发表于 2009-12-20 17:36 |只看该作者
原帖由 HF.SKY000 于 2009-12-20 16:13 发表
不知道还有其它方法没有?


文件10M左右,还不算大,可以一次读入后,匹配一次即可:
my @lines = <$hFile>;
my $match = join( "", @lines);
$match =~ /PART。3(.*)PART。4/s;
$1就是了~

论坛徽章:
1
狮子座
日期:2013-12-16 16:09:24
9 [报告]
发表于 2009-12-20 23:08 |只看该作者

回复 #8 dugu072_cu 的帖子

狠!

论坛徽章:
78
双子座
日期:2013-10-15 08:50:09天秤座
日期:2013-10-16 18:02:08白羊座
日期:2013-10-18 13:35:33天蝎座
日期:2013-10-18 13:37:06狮子座
日期:2013-10-18 13:40:31双子座
日期:2013-10-22 13:58:42戌狗
日期:2013-10-22 18:50:04CU十二周年纪念徽章
日期:2013-10-24 15:41:34巨蟹座
日期:2013-10-24 17:14:56处女座
日期:2013-10-24 17:15:30双子座
日期:2013-10-25 13:49:39午马
日期:2013-10-28 15:02:15
10 [报告]
发表于 2009-12-22 13:48 |只看该作者
原帖由 dugu072_cu 于 2009-12-20 15:18 发表
if(/PART。3/../PART。4/) {
   do sth...
}


这个怎么理解呢?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP