曲径通幽论坛

标题: 使用 grep 的 -o 和 -E 选项进行正则的精确匹配 [打印本页]

作者: beyes    时间: 2011-12-16 17:09
标题: 使用 grep 的 -o 和 -E 选项进行正则的精确匹配
sed 命令可以很好的进行行匹配,但从某一行中精确匹配某些内容,则使用 grep 命令并辅以 -o 和 -E 选项可达到此目的。其中 -o 表示“only-matching”,即“仅匹配”之意。光用它不够,配合 -E 选项使用扩展正则表达式则威力巨大。

比如下面有一条文本 tmp.txt ,其中内容为:
<?xml version="1.0" encoding="utf-8"?><ajax><![CDATA[{"aid":45,"path":"attachment/Mon_1112/2_1_5728040df3ab346.jpg"}]]></ajax>
我们想从中过略出 aid 的值即 45 ,那么可以先如下这么做:
grep -o -E 'aid":[1-9]*' tmp.txt
得到的结果为:
aid":45
这时就好办了,我们可以使用 awk 的 -F 选项指示出冒号分隔符,这样就容易过滤出 45 这个值来,整个命令综合如下:
grep -o -E 'aid":[1-9]*' tmp.txt |awk -F: '{print $2}'





欢迎光临 曲径通幽论坛 (http://www.groad.net/bbs/) Powered by Discuz! X3.2