grep
es una poderosa herramienta de línea de comandos que le permite buscar líneas que coincidan con una expresión regular en uno o más archivos de entrada y escribir cada línea coincidente en la salida estándar.
En este artículo, le mostraremos cómo usar GNU grep
para buscar múltiples cadenas o patrones.
Grep Multiple Patterns #
GNU grep
admite tres sintaxis de expresiones regulares, básica, extendida y compatible con Perl. Cuando no se especifica ningún tipo de expresión regular, grep
interpretar patrones de búsqueda como expresiones regulares básicas.
Para buscar varios patrones, utilice el operador OR (alternancia).
El operador de alternancia |
(tubería) le permite especificar diferentes coincidencias posibles que pueden ser cadenas literales o conjuntos de expresiones. Este operador tiene la precedencia más baja de todos los operadores de expresiones regulares.
La sintaxis para buscar múltiples patrones usando grep
expresiones regulares básicas es la siguiente:
grep 'pattern1\|pattern2' file...
Encierre siempre la expresión regular entre comillas simples para evitar la interpretación y expansión de los metacaracteres por parte del shell.
Cuando se utilizan expresiones regulares básicas, los metacaracteres se interpretan como caracteres literales. Para mantener los significados especiales de los metacaracteres, se deben escapar con una barra invertida (\
). Es por eso que estamos escapando del operador OR (|
) con una barra inclinada.
Para interpretar el patrón como una expresión regular extendida, invoque grep
el -E
(o --extended-regexp
) opción. Cuando use expresiones regulares extendidas, no escape el |
operador:
grep -E 'pattern1|pattern2' file...
Para obtener más información sobre cómo construir expresiones regulares, consulte nuestro artículo Grep regex.
Grep Multiple Strings #
Las cadenas literales son los patrones más básicos.
En el siguiente ejemplo, buscamos todas las apariciones de las palabras fatal
, error
y critical
en el archivo de error de registro de Nginx:
grep 'fatal\|error\|critical' /var/log/nginx/error.log
Si la cadena que está buscando incluye espacios, escríbala entre comillas dobles.
Aquí está el mismo ejemplo usando la expresión regular extendida, que elimina la necesidad de escapar del operador |
grep -E 'fatal|error|critical' /var/log/nginx/error.log
Por defecto, grep
distingue entre mayúsculas y minúsculas. Esto significa que los caracteres en mayúsculas y minúsculas se tratan como distintos.
Para ignorar mayúsculas y minúsculas al buscar, invoque grep with
el -i
opción (o --ignore-case
):
grep -i 'fatal\|error\|critical' /var/log/nginx/error.log
Al buscar una cadena, grep
mostrará todas las líneas donde la cadena está incrustada en cadenas más grandes. Entonces, si estaba buscando "error", grep
también imprimirá las líneas donde "error" está incrustado en palabras más grandes, como "sin errores" o "antiterroristas".
Para devolver solo aquellas líneas en las que la cadena especificada es una palabra completa (entre caracteres que no son palabras), use -w
(o --word-regexp
) opción:
grep -w 'fatal\|error\|critical' /var/log/nginx/error.log
Los caracteres de palabras incluyen caracteres alfanuméricos (a-z, A-Z y 0-9) y guiones bajos (_). Todos los demás caracteres se consideran caracteres que no son palabras.
Para más detalles sobre grep
opciones, visite nuestro artículo Comando Grep.
Conclusión #
Le hemos mostrado cómo grep
para buscar múltiples patrones, cadenas y palabras.
Si tiene alguna pregunta o comentario, no dude en dejar un comentario.