No exemplo a seguir, sed
corresponde às linhas que começam com a a
ou a c
e imprime o primeiro caractere dessa linha ( a
ou c
):
$ echo "ag
bh
ci
dj
ek
fl" | sed 's/\(a\|c\)./\1/' # Matches lines starting with 'a' or 'c'.
output:
a
bh
c
dj
ek
fl
No entanto, as linhas que não correspondem ao padrão também são impressas. Como digo sed
para omitir as linhas que não correspondem ao padrão? Posso obter o efeito desejado combinando-o com grep
(a seguir), mas gostaria de saber se é sed
possível conseguir isso "sozinho".
$ echo "ag
bh
ci
dj
ek
fl" | grep '[ac]' | sed 's/\(a\|c\)./\1/'
output:
a
c
Não importa para o que você realmente queria saber, mas seu padrão deve começar com ^, para que esteja ancorado no início da linha. Conforme codificado, ele corresponderia a ou c em qualquer lugar da linha, desde que não seja o último caractere.
—
31413 Joe