Tengo archivo con estas lineas
G8 = P(G1,G3)
G9 = P(G3,G4)
G12 = P(G2,G9)
G15 = P(G9,G5)
G16 = P(G8,G12)
G17 = P(G12,G15)
Necesito la salida como
G1,G3
G3,G4
.....
¿Cómo puedo hacerlo con el comando sed / grep o usando perl?
Algunas otras formas:
sed
sed 's/.*(\(.*\))/\1/' file perl
perl -pe 's/.*\((.*)\)/$1/' file
o
perl -lanF"[()]" -e 'print $F[1]' file
o
perl -pe 's/.*\((.+?)\).*/$1/;' file awk
awk -F"[()]" '{print $2}' file cáscara
while IFS="()" read a b; do echo "$b"; done < file
-Fte permite elegir qué personaje (s) usará awk para dividir la línea en campos. Aquí, le doy una clase de caracteres ([]) que consiste en abrir y cerrar paréntesis. Entonces dividirá la línea una(y otra vez). Como resultado, el segundo campo será el contenido de los paréntesis. Por ejemplo, con la cadenaG8 = P(G1,G3)foo,$1seráG8 = P,$2seráG1,G3y$3seríafoo.Hay más de una forma de hacerlo:
o:
fuente
Eso busca el paréntesis de apertura, lo ignora, luego imprime todos los caracteres que no están entre paréntesis que siguen.
Requiere GNU grep
fuente
sed 's/^.*(//;s/)$//' /path/to/filePara desglosar esto:
sedes elstemblor itored.'s/^.*(//;s/)$//'es el script que se envíased, que se desglosa de la siguiente manera:fuente
fuente
fuente
awk -F"[()]" '{print $2}' filecomo en la respuesta de