LinuxParty
Las expresiones regulares (regexps) son unas muy poderosas herramientas, que le permite buscar cadenas de texto que coinciden con un patrón particular. En esta primera parte de una serie de dos partes, voy a mirar a su utilización en la línea de comandos. La siguiente parte abarcará las expresiones regulares en los editores y otros programas.
El intérprete de comandos incorpora la prestación "comodín"
Hay algunas básicas expresiones regulares (regexps) integradas en la shell: el ejemplo más básico de esto es el comodín *. Este ejemplo mostrará todos los archivos en el directorio actual que tiene la extensión. Jpg:
ls *.jpg
Lo que realmente ocurre aquí es que la shell amplía el * antes de que pasarle la lista de archivos a ls. De modo que la línea es realmente equivalente a
ls file1.jpg file2.jpg ...
Por el contrario, esta línea de comandos producirá la misma salida, pero usando grep con la sintaxis regexp completo
ls | grep '.*.jpg'
Esto ejecuta ls en el directorio actual (para mostrar una lista de todos los archivos), entonces pasa la salida a través de grep, que utiliza expresiones regulares "propias", en lugar del comando del shell. Aquí, tras grep y abrir la comillas
- el punto que hay detrás . significa "cualquier carácter",
- y * significa '0 o más caracteres precedentes (o anteriores): así .* es "0 o más de cualquier carácter". Es usado para escapar el segundo período (es decir concluye la orden .* donde empieza otra nueva...), por lo que es asimilado a un período real en lugar de un caracter suplente para 'cualquier carácter'. es decir, obtendremos los archivos que terminan. jpg.
Tenga en cuenta la diferencia entre este y el realizado en la shell integrada, donde un período es tratado como período real, y * significa "cualquier carácter".
Las comillas simples son muy importantes! Sin las comillas simples, la shell intentará realizar la expansión antes de ejecutar el comando, y resultarán cosas extrañas. Siempre comilla simple en sus expresiones regulares en la línea de comandos.
La disposición comodín de la shell puede ser muy útil. Lo importante es recordar que la sintaxis no es exactamente el mismo que para la propia de las expresiones regulares. Aquí hay otro comando del shell en el ejemplo, que se trasladará a todos los registros de su edad (que en mi sistema se nombran como mail.log.0.gz,system.log.1.bz2, etc) a un subdirectorio específico:
mv *.log.[0-9].* logarchive/
[0-9] se corresponderá con cualquier carácter entre 0 y 9: funciona con expresiones regulares adecuados, así como con la shell incorporada.
Artículo siguiente: Expresiones Regulares en Linux II
-
Linux
- Cambiar la Hora y la Fecha al sistema Linux
- Montar un directorio remoto, vía NFS, en Linux
- Predicciones de Linux para 2025
- Elementary OS 8: una distribución de Linux para usuarios de Windows y macOS
- Renombrar multiples archivos masivamente en Linux (quitar espacios, cambiar mayúsculas) a la vez en Linux
- He utilizado Linux durante 30 años. Aquí hay 5 razones por las que nunca cambiaré a Windows o MacOS
- Mis predicciones sobre Linux para 2025: será un buen año
- ¿Por qué Torvalds eliminó a los encargados rusos del mantenimiento del núcleo de Linux?
- 10 cosas que siempre hago después de instalar Linux (y por qué tú también deberías hacerlo)
- 7 cosas que nunca hago después de instalar Linux (y por qué tú tampoco deberías)
- Detección de Intrusos: Snort, Base, MySQL, y Apache2 en Ubuntu Linux 7.10
- ¿Por qué no más personas usan Linux en el escritorio? Tengo una teoría que quizás no te guste.
- Los países occidentales ricos lideran la expansión mundial del petróleo y el gas
- Systemd 256.1 aborda la queja de que 'systemd-tmpfiles' podría eliminar inesperadamente su directorio /home
- Por qué un kernel Linux de distribución 'congelada' no es la mejor opción para la seguridad
Comentarios
Estoy aprendiendo a usar las regexp desde vi tengo un documento y estoy buscando las palabras error o fail y sus derivados errors o failed o failure etc y mi regexp es:
:/\(.*\(error|fail\).*\)/
Al ejecutarla me dice que no hay coincidencias :( pero para
:/\(.*\(error\).*\)/
o
:/\(.*\(fail\).*\)/
Si encuentra coincidencias, podrían decirme como me estoy equivocando??
:/.error/.fail
Entras en vim, y escribes
:help
Escribes
:set mouse=a
Buscas "search", escribiendo:
/search
En la búsqueda te aparecerá el fichero pattern.txt, con las expresiones regulares, y nos dices como lo solucionastes, está en inglés pero es fácil de entender.
:/.*error\&.*fail
Si encuentras algo, comentarlo, gracias