Las cadenas en Linux son una secuencia de caracteres que puede utilizarse como un valor o una variable en un programa. Las cadenas en Linux pueden contener letras, números, símbolos y espacios en blanco, y se emplean comúnmente en scripts de shell y programas de línea de comandos. Ahora veremos cómo hacer búsqueda de cadenas en Linux, una utilidad nativa del sistema operativo.
¿Qué son las cadenas en Linux?
En la mayoría de los lenguajes de programación, las cadenas se pueden representar utilizando comillas simples ( ‘ ‘ ) o dobles ( ” ” ). Por ejemplo, en Bash (un popular intérprete de comandos de Linux), una cadena puede definirse de la siguiente manera:
//grep -v , grep -r , grep en linux
cadena = "Hola Keepcoding"
En este ejemplo, la variable cadena
contiene la cadena “Hola Keepcoding”. La cadena se almacena en memoria como una secuencia de caracteres consecutivos, y se puede acceder y manipular utilizando diversas herramientas y funciones de programación.
Buscar cadenas en Linux
Para buscar cadenas en Linux se pueden buscar cadenas ASCII o Unicode en cualquier dispositivo de bloques (fichero, disco, partición). Estas cadenas estarán unidas con grep y requerirán una serie de comandos, entre ellos:
- -i: case sensitive
- -v: no mostrar
- -r: recursivo
- -B num: muestra num líneas antes (before) de la ocurrencia.
- -A num: muestra num líneas después (after) de la ocurrencia.
Cadenas ASCII o Unicode
ASCII y Unicode son dos estándares de codificación de caracteres que se utilizan para representar texto en la mayoría de los sistemas informáticos, incluyendo Linux.
ASCII (American Standard Code for Information Interchange) es un estándar de codificación que se desarrolló en los años 60 para representar caracteres en inglés y otros idiomas occidentales en los sistemas informáticos. El estándar ASCII define un conjunto de 128 caracteres, incluyendo letras mayúsculas y minúsculas, números, símbolos y caracteres de control.
🔴 ¿Quieres entrar de lleno a la Ciberseguridad? 🔴
Descubre el Ciberseguridad Full Stack Bootcamp de KeepCoding. La formación más completa del mercado y con empleabilidad garantizada
👉 Prueba gratis el Bootcamp en Ciberseguridad por una semanaUnicode, por otro lado, es un estándar de codificación mucho más amplio que se desarrolló en los años 90 para representar todos los caracteres de todos los idiomas del mundo. Unicode incluye más de 143,000 caracteres diferentes, que se pueden representar utilizando diferentes conjuntos de codificación, como UTF-8, UTF-16 y UTF-32.
¿Qué es grep?
Grep es una herramienta de línea de comandos muy útil para buscar cadenas en archivos y directorios. El comando grep busca una cadena específica en uno o varios archivos y muestra todas las líneas que contienen la cadena buscada.
El formato general del comando grep es el siguiente:
grep [opciones] cadena archivo
Aquí, cadena
es la cadena que se desea buscar, y archivo
es el archivo en el que se quiere buscar la cadena. Si se desea buscar la cadena en varios archivos, se pueden especificar múltiples archivos separados por espacios.
Veamos algunos comandos u opciones comunes que se pueden utilizar para buscar cadenas en Linux con grep:
-i
La opción -i en el comando grep de búsqueda de cadenas en Linux se usa para realizar una búsqueda que no distingue entre mayúsculas y minúsculas. Esto significa que el comando encontrará todas las apariciones de la cadena de caracteres especificada, ya sea en mayúsculas o minúsculas.
Por ejemplo, si usamos el comando grep -i 'hola' archivo.txt
, encontrará todas las apariciones de hola, Hola, HOLA
y todas las demás variantes de mayúsculas y minúsculas de hola
en el archivo archivo.txt
.
Es importante tener en cuenta que la opción -i es sensible al idioma y la configuración regional del sistema, lo que significa que el comportamiento exacto puede variar según el sistema utilizado.
–r
Esta opción de búsqueda de cadenas en Linux se utiliza para buscar de forma recursiva en los subdirectorios de un directorio dado.
Por ejemplo, si se quiere buscar una cadena de texto en todos los archivos con extensión “.txt” en un directorio y sus subdirectorios, se puede utilizar el siguiente comando:
grep -r "cadena_de_texto" /ruta/del/directorio
El comando “grep” buscará de manera recursiva la cadena de texto en todos los archivos de texto dentro del directorio especificado y sus subdirectorios.
–n
Esta opción de búsqueda de cadenas en Linux se utiliza para imprimir el número de línea correspondiente para cada línea coincidente en el archivo.
Mezclar opciones
Si queremos, podemos mezclar diferentes opciones en el comando grep para hacer búsquedas más exactas. Veamos:
¿Cómo seguir aprendiendo sobre ciberseguridad?
Ya hemos visto cómo hacer búsqueda de cadenas en Linux. Si quieres seguir formándote en las distintas disciplinas de la seguridad informática, en KeepCoding tenemos el Ciberseguridad Full Stack Bootcamp, la formación con la que puedes convertirte en un gran profesional IT con la guía de profesores expertos en la materia. ¡Pide más información y transforma ya mismo tu vida profesional!