和tee 类似啊,同步输出log  ,

open my $F1,     ' XXXcmd | " ;

while ( <$F1> )  {
     print  ;
}





2009/9/26 zheng wen <[email protected]>

> 方法2没看懂。。
>
> 2009/9/23 Michael Zeng <[email protected]>:
> > 1用 File::ReadBackwards  :
> > http://search.cpan.org/~uri/File-ReadBackwards-1.04/ReadBackwards.pm
> >
> > 2. 用管道:
> >  open my $F1, " XXX cmd | " ;
> > while (<$F1>) {
> > ...
> > }
> > 该管道和命令输出是同步的,和 |tee类似
> >
> > 3。 seek +tell 也可以啊,自己可以控制
> >
> >
> >
> > 2009/9/23 msmouse <[email protected]>
> >>
> >> 针对字节的就行呗,自己查换行
> >>
> >> 另外tac应该到处有吧?
> >> ----------------------------------
> >> [email protected]
> >> [email protected]
> >>
> >>
> >> 2009/9/23 zheng wen <[email protected]>
> >>>
> >>> 现在处理一个log文件,想分析最近几分钟的log,现有以下方案:
> >>> 1,用tail是可以的,但是不太好估计tail多少行,tail N行->判断->tail 2N行 貌似可以动态判断,但比较繁琐,个人不赞成
> >>> 2,从前面正向读的话觉得读了前面一堆没有必要的行,文件大了会很慢,循环里面有一堆正则处理的东西
> >>> 3,用tac file | 然后读管道,貌似比较不错,但不是很清楚所有server上是否都有tac命令,而且也不知道性能怎样?
> >>> <4>,Perl里面从文件末尾开始向前读,不知道有没有简单的办法可以实现?seek tell的位置貌似都针对字节的。
> >>>
> >>> 针对4,有什么方法实现么?或者有没有其他的方案。简单有效的最好。
> >>>
> >>> 谢谢!
> >>>
> >>>
> >>
> >>
> >>
> >> --
> >>            Yours Sincerely
> >>                    Zeng Hong
>  >>
> >> >>
> >
>
> >
>


-- 
           Yours Sincerely
                   Zeng Hong

--~--~---------~--~----~------------~-------~--~----~
您收到此信息是由于您订阅了 Google 论坛“PerlChina Mongers 讨论组”论坛。
 要在此论坛发帖,请发电子邮件到 [email protected]
 要退订此论坛,请发邮件至 [email protected]
 更多选项,请通过 http://groups.google.com/group/perlchina?hl=zh-CN 访问该论坛
-~----------~----~----~----~------~----~------~--~---

回复