linux下如何获得特定字符串前后几行文本

如果要获得一个文件中的最后几行,使用tail命令就可以很方便的实现。但在有些时候,会需要用到如标题中所描述的功能。

我举一个具体的例子:在使用VASP计算弹性常数时,结果就是在字符串“TOTAL ELASTIC MODUII” 之后的几行,但这整个部分是在文件的中间,如果将这部分数据提取出来呢?

使用grep命令可以比较轻松达到目的,具体使用如下:

$ grep -A|B n "key" file

其中:

  • A:表示在字符串之前
  • B:表示在字符串之后
  • n:要获取多上行文本
  • key:为要查找的字符串
  • file:文件名

比如上面提到的例子中,可以使用如下命令获取弹性常数:

$ grep -A 10 "TOTAL ELASTIC" OUTCAR

获取的几行文本可以通过管道传递给其他命令进行进一步的提取或使用。

参考:http://walakq.i.sohu.com/blog/view/168796199.htm

标签: linux, grep

相关文章推荐

添加新评论 (无需注册,可直接评论)