
Me gustaría manipular el siguiente resultado de esta manera:
Producción:
S* 0.0.0.0/0 [1/0] via 1.1.1.1, MAR-LNK-VGL_DSL
[1/0] via 2.2.2.2, MAR-LNK-GVT_DSL
[1/0] via 3.3.3.3, ENT-LNK-OI_CORP
[1/0] via 4.4.4.4, ENT-EBT_CORP, [10/0]
S 10.0.0.0/16 [10/0] via 5.5.5.5, ENT-LNK
C 10.5.10.0/24 is directly connected, MAR-DEV-LAN
C 10.5.20.0/24 is directly connected, MAR-DEV-DMZ
C 10.5.30.0/24 is directly connected, MAR-DEV-BALANCE
C 10.6.40.0/28 is directly connected, BNC-HOM
C 10.6.40.3/32 is directly connected, BNC-HOM
B 10.7.0.0/21 [20/100] via 6.6.6.6, vpn-21fce533-0, 03:12:51
S 10.19.210.56/29 [10/0] via 7.7.7.7, MAR-EMB_MPLS
S 10.19.233.0/24 [10/0] is directly connected, VPN-HML-PP
S 10.19.252.0/24 [5/0] is directly connected, VPN-CON
B 10.19.254.0/24 [20/0] via 8.8.8.8, ENT_EBT_MPLS, 4d20h13m
S 10.20.0.4/32 [10/0] is directly connected, VPN-AX4B
S 10.33.13.70/32 [10/0] is directly connected, VPN-NEW
B 10.50.0.0/17 [20/0] via 9.9.9.9, SEC-EQNX, 00:02:11
B 10.50.128.0/17 [20/0] via 9.9.9.9, SEC-EQNX, 00:02:11
O 100.0.153.164/32 [110/200] via 99.1.152.61, HUB-MAR-03_79, 17:36:22
[110/200] via 99.1.101.217, HUB-MAR-04_54, 17:36:22
[110/200] via 99.1.101.153, HUB-MAR-04_38, 17:36:22
[110/200] via 99.1.151.13, HUB-MAR-03_3, 17:36:22
O 100.0.252.11/32 [110/200] via 99.1.151.109, HUB-MAR-03_15, 03:22:24
[110/200] via 99.1.102.17, HUB-MAR-04_68, 03:22:24
Si filtro por 100.0.153.164/32, imprimiría el siguiente resultado:
O 100.0.153.164/32 [110/200] via 99.1.152.61, HUB-MAR-03_79, 17:36:22
[110/200] via 99.1.101.217, HUB-MAR-04_54, 17:36:22
[110/200] via 99.1.101.153, HUB-MAR-04_38, 17:36:22
[110/200] via 99.1.151.13, HUB-MAR-03_3, 17:36:22
Si filtro por 0.0.0.0/0, el resultado sería:
S* 0.0.0.0/0 [1/0] via 1.1.1.1, MAR-LNK-VGL_DSL
[1/0] via 2.2.2.2, MAR-LNK-GVT_DSL
[1/0] via 3.3.3.3, ENT-LNK-OI_CORP
[1/0] via 4.4.4.4, ENT-EBT_CORP, [10/0]
Y si filtro por algo como 10.20.0.4/32, el resultado sería:
S 10.20.0.4/32 [10/0] is directly connected, VPN-AX4B
Pero no soy bueno con eso, así que no puedo entenderlo :(
Respuesta1
Si desea hacer coincidir una cadena determinada en el segundo campo e imprimir "líneas de continuación" después de que esa cadena haya coincidido, pruebe este script awk.
awk -v fltr="_str_" 'BEGIN {havematch=0}
{if ($1 ~ /^----/) {
if (havematch == 1) {
print $0
}
next
}
if ($2 == fltr) {
print $0
havematch=1
next
}
{havematch=0}
}' _file_
Lo he dividido para que sea más fácil de leer.
Básicamente, comienzas inicializando la variable havematch a cero, ya que no tienes ninguna coincidencia al principio. Luego, verifica si una línea comienza con "----". Si es así, y la variable havematch está configurada, imprime esta línea ya que es una "línea de continuación" si la línea comienza con "----" y havematch se establece en cero, entonces esta es una línea de continuación para otra cosa. No lo imprimas. De cualquier manera, si la línea comienza con "----", después de verificar la coincidencia, pase a la siguiente línea.
Si el segundo campo de la línea coincide con su cadena de filtro, imprima la línea y establezca la variable havematch en uno. Pase a la siguiente línea.
Si la línea no es una línea de continuación y el segundo campo no coincide con su cadena de filtro, entonces esa línea no coincide y no desea imprimir ninguna línea de continuación. Entonces, establezca la variable havematch en cero.
Espero que esto ayude.