Chinaunix

标题: 如何用AWK打印匹配行开始往上第N行? [打印本页]

作者: justlooks    时间: 2008-12-07 13:33
标题: 如何用AWK打印匹配行开始往上第N行?
比如

111111111
22222222    (需要打印的)
5
此行匹配
............

我要打印匹配行开始上数的第3行该怎么用AWK写?
作者: cjaizss    时间: 2008-12-07 13:55
一次遍历

  1. awk '/...../{print a[1];print a[2];print}{a[1]=a[2];a[2]=$0}' urfile
复制代码

两次遍历

  1. awk 'FNR==NR{if($0~/...../)a[NR]="y";}FNR!=NR{if(a[NR]=="y"||a[NR+1]=="y"||a[NR+2]=="y")print}' urfile urfile
复制代码

作者: ly5066113    时间: 2008-12-07 14:07
grep -B3 '......' urfile

[ 本帖最后由 ly5066113 于 2008-12-7 14:16 编辑 ]
作者: justlooks    时间: 2008-12-07 14:29
标题: 回复 #2 cjaizss 的帖子
如果行数很大的 话,这2个解法需要的变量岂不是好多.........
作者: justlooks    时间: 2008-12-07 14:31
我觉得先把文本逆序打印 在搜索匹配行往下数N行 打印输出会比较好

awk '{a[i++]=$0}END{for(j=i-1;j>=0print a[j--]}' dfile|awk '/regex/{for(i=1;i<N;i++)getline;print}'

[ 本帖最后由 justlooks 于 2008-12-7 14:38 编辑 ]
作者: cjaizss    时间: 2008-12-07 14:41
原帖由 justlooks 于 2008-12-7 14:29 发表
如果行数很大的 话,这2个解法需要的变量岂不是好多.........

行数大了,用循环,减少赋值可以用循环队列。
作者: ynchnluiti    时间: 2008-12-07 14:44
原帖由 justlooks 于 2008-12-7 14:31 发表
我觉得先把文本逆序打印 在搜索匹配行往下数N行 打印输出会比较好

awk '{a=$0}END{for(j=i-1;j>=0print a[j--]}' dfile|awk '/regex/{for(i=1;i

这个最后输出的行序跟原来相反了
作者: ly5066113    时间: 2008-12-07 15:55
标题: 回复 #4 justlooks 的帖子
更为通用的是取余:

  1. awk '/....../{for(i=NR;i<NR+3;i++) print a[i%3];print}{a[NR%3]=$0}' urfile
复制代码

作者: bigqueues    时间: 2008-12-07 20:49
标题: 回复 #3 ly5066113 的帖子
老版本的grep没有 -B -A
:S
作者: 寂寞烈火    时间: 2008-12-08 14:44
http://bbs.chinaunix.net/thread-624057-1-1.html
作者: justlooks    时间: 2008-12-08 15:17
标题: 回复 #10 寂寞烈火 的帖子
貌似楼上连接里的 比较复杂

打印从匹配行开始计数的第N行

awk '/regex/{for(i=1;i<=N;i++)getline;print $0}' file




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2