
Por exemplo, meu arquivo é como:
59 6 18 2014 169 7 14 2 7671912 7849744 201 4
60 6 19 2014 170 5 49 2 7671912 7849744 201 5
61 6 20 2014 171 6 8 2 7671912 7849744 201 6
62 6 23 2014 174 5 3 2 7671912 7849744 201 7
63 6 23 2014 174 7 17 2 7671912 7849744 201 8
64 6 24 2014 175 16 13 2 7671912 7849744 201 9
65 6 25 2014 176 8 20 2 7671912 7849744 201 10
10
1 1 49 6 16 2014 7 39 201 1 0 1043 <au_launchpad_back.gif> 201 gif <SIZE> 871
1 2 49 6 17 2014 13 15 201 1 0 1043 <au_launchpad_back.gif> 201 gif <SIZE> 871
1 3 49 6 18 2014 1 38 201 1 0 1043 <au_launchpad_back.gif> 201 gif <SIZE> 871
1 4 49 6 18 2014 7 14 201 1 0 1043 <au_launchpad_back.gif> 201 gif <SIZE> 871
1 5 49 6 19 2014 5 49 201 1 0 1043 <au_launchpad_back.gif> 201 gif <SIZE> 871
Preciso imprimir a linha anterior da entrada de token único "10", que deve ser
65 6 25 2014 176 8 20 2 7671912 7849744 201 10
Como posso fazer isso?
Responder1
Você pode usarawk
:
awk 'NF == 1 { print LAST } { LAST=$0 }' < datafile
Isso salva cada linha do arquivo ( LAST=$0
) à medida que avança, e quando uma linha tem apenas um registro ( NF == 1
- NF
é o número de tokens na linha, grosso modo), ele imprime a linha anterior salva.
Responder2
Se você tiver apenas uma ocorrência do token, poderá fazer isso com GNU grep
e head
:
grep -x -B 1 10 file | head -n 1
Diz -B 1
para grep
imprimir a linha correspondente e a anterior. Com a -x
opção, grep 10
as correspondências em linhas que são x
efetivamente 10
(em oposição acontendo 10
). Por fim, head -n 1
imprime apenas a primeira das linhas resultantes.
Responder3
sed
Você pode usar sed
:
sed -e '/^10$/{x;p;}' -e 'x;d' < datafile
Explicação:
O endereço /^10$/
corresponde à linha que contém 10. Quando corresponde, a seguinte série de comandos é executada, {x;p;}
, que troca ( x
) o espaço de espera pelo espaço padrão e depois imprime ( p
) o espaço padrão.
O espaço de espera contém a linha anterior por causa do restante do script. Para cada linha do arquivo, troque ( x
) o espaço de espera pelo espaço padrão e, em seguida, exclua ( d
) tudo o que estiver no espaço padrão.
Ao contrário do primeiro comando, que possui um prefixo de endereço que faz com que ele corresponda apenas quando a linha 10 for vista, esses comandos não possuem prefixo e, portanto, correspondem a todas as linhas do arquivo. O resultado líquido é que continuamos colocando a última linha vista no espaço de espera, e o fato de excluirmos o espaço padrão significa que não há outra saída além da nossa saída explícita quando vemos 10.