1.在文件numbers.txt中搜索包含6个连续数字,后面紧接着字符"."的所有行
[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个不知道我的理解对不对,第四个我还是不明白,恳请大神指点下。非常感谢!

解决方案 »

  1.   

    1、^是行首定位符,表示以6个数字 加 一个 . 开头的
    2、方法三,你匹配的是 词首 是6个数字加一个. 的,不管这个单词后面还有没有,所以那几个都会匹配
    3、你没有加其他限定条件,grep会按字符顺序依次匹配,例如方法1    1234567.  它先从1开始,发现前面6个数字能匹配上,但是第7个字符不是点,然后又从2开始匹配,发现符合条件,所以就匹配上了
    4、方法4,我也不太懂,你加上了词首定位符合词尾定位符,按理说应该是连续字符为一个词,但是这里好像把 点 排除在单词之外了。可能我解错了吧,这个不太明白。