今天用grep查log遇到了一件嗶了狗的事。
我用vim打開log文件,里面有sysTid=3800這一行。但是grep "sysTid=3800" filename竟然找不到!
然后我grep "sysTid=xxxxx" xxxxx是另外一個數字,可以找到。。。另外如果用egrep "*sysTid.*3800*"也可以找到。。。簡直嗶了狗好嗎!
一開始以為我是不是正則表達式用錯了,是不是=要轉義才行。但怎么查都不需要,而且加了\也一樣不行。
后來注意到,搜索并不是完全沒有結果,而是提示匹配到二進制文件。難道實際上已經匹配了,但grep認為是二進制文件?
于是去谷歌搜egrep match binary file,果然grep如果碰到\000 NUL字符,就會認為文件是二進制文件。必須加上-a或--text選項強制讓grep認為是文本文件才可以看到正常的結果。
問題本身是解決了,但本質還沒有完全搞清楚:為什么搜索其它的字符串不會有這個提示?為什么egrep "*sysTid.*3800*"也不會有這個提示?
讓人費解的grep機制。。