[liuqiang@mu01 grepTest]$ cat numbers.txt
123214.
0987654 456789.678 9 192
1234567.
222111. 21.
[liuqiang@mu01 grepTest]$ grep '[0-9]\{6\}\.' numbers.txt //方法1
123214.
0987654 456789.678 9 192
1234567.
222111. 21.
[liuqiang@mu01 grepTest]$grep '^[0-9]\{6\}\.' numbers.txt //方法2
123214.
222111. 21.
[liuqiang@mu01 grepTest]$ grep '\<[0-9]\{6\}\.' numbers.txt //方法3
123214.
0987654 456789.678 9 192
222111. 21.
[liuqiang@mu01 grepTest]$ grep '\<[0-9]\{6\}\.\>' numbers.txt //方法4
[liuqiang@mu01 grepTest]$
以上,存在几个问题:
1. 方法2中^[XXX]的这种形式,指的是加了^之后,就必须满足完整匹配,即刚好6个数字才行的字符串,所以456789.678 这行是不行。
2. 方法3中使用字符串限定的方式,并没有考虑结尾,因此456789.678 被选中。
3. 传统的方法是方法1,但是方法1显然只是考虑包含的关系,因此1234567. 明明是7个数字,也被选中。
4. 为什么方法4的执行结果为空?
以上4个问题,前面3个不知道我的理解对不对,第四个我还是不明白 。
非常感谢!