BASH – Script que solicita nombre de un archivo y si no se ingresa en 10 segundos (TIMEOUT) asigna el valor main-file.txt.

Publicado en Unix - Linux | Deja un comentario

SCRIPTS – Cambiar un valor por otro en archivo, en BASH y PERL.

Para este ejemplo utilizaremos un archivo llamado «traspaso.txt» el cual contiene los siguientes datos :

Queremos cambiar el valor «Nissan» por «Toyota», pudiendo realizarlo de la siguiente manera en SCRIPTS BASH :

Por último, podemos realizar el cambio con perl, pasando por la terminal o consola la siguiente orden :

Publicado en Unix - Linux | Deja un comentario

BASH – Script para realizar cambio masivo de contraseñas en servidores (Con uso de EXPECT).

Recordemos que expect es una librería que automatiza de forma interactiva los scripts, así que si no tienes instalado ésta utilidad, para poder utilizar éste script deberás tenerlo previamente.

A continuación except hace el cambio de forma interactiva :

Publicado en Unix - Linux | Deja un comentario

BASH – Script de procesamiento en paralelo.-

Supongamos que tienes una lista de URLs de sitios web y deseas extraer el título de cada página para realizar un análisis posterior. En lugar de procesar cada URL secuencialmente, puedes aprovechar el procesamiento en paralelo para acelerar el proceso. Aquí hay un ejemplo de cómo podrías hacerlo,

Publicado en Unix - Linux | Deja un comentario

Linux – Comando MAPFILE para Asignar a una variable los valores de las líneas de un archivo.-

El comando mapfile ofrece una solución poderosa pero simple, que le permite leer sin esfuerzo líneas desde una entrada estándar (o un descriptor de archivo específico) en una variable de matriz. mapfile está disponible en Bash versión 4.0 y posteriores. La estructura de mando es la siguiente:

mapfile [options] array_variable < input_file

En el siguiente ejemplo, veremos cómo procesar datos CSV. Supongamos que tenemos un archivo CSV con los siguientes datos.

Al proceesar el archivo CVS «data.cvs», necesitamos separar las filas y tambien las columnas. Esto para mostarr los campos por separado de cada linea

Al ejecutarlo nos mostrara el siguiente resultado :

Publicado en Unix - Linux | Deja un comentario

Linux – Comando READARRAY para leer líneas de un archivo en una matriz 2D.-

El ‘readarray’ es uno de los comandos más útiles en Bash. Este, lee líneas de un archivo o entrada estándar y las asigna a una matriz. Este comando solo está disponible en versiones de bash 4.0 o superior.

La sintaxis para usar ‘readarray’ es la siguiente:

Las opciones disponibles para el comando ‘readarray’ son:

‘-d DELIM’: establece el delimitador que se utilizará al dividir líneas en elementos de matriz y, de forma predeterminada, el delimitador es un carácter de nueva línea.

‘-n COUNT’: especifica el número máximo de líneas para leer en la matriz.

‘-O ORIGIN’: establece el índice inicial de la matriz.

‘-s COUNT’: especifica el número de líneas que se saltan antes de leer en la matriz.

‘-t’: elimina el carácter de nueva línea final de cada línea leída en la matriz.

Suponga que tiene una matriz que contiene una combinación de caracteres alfabéticos y numéricos. Para realizar la clasificación en esta matriz, debe comparar el valor ASCII del carácter.

El código para nuestro ejemplo será como el siguiente.

Después de ejecutar el script, obtendrá un resultado como el que se muestra a continuación.

Otro  ejemplo del uso de ‘readarray’ para leer líneas de un archivo en una matriz 2D y para eso he creado un testfile.txt cuyo contenido es:

1 2 3

4 5 6

7 8 9

Script bash,  que demuestra el uso del comando ‘readarray’:

Primero se declara una matriz 2D llamada ‘matriz’ y luego uso el comando ‘readarray’ para leer líneas de un archivo llamado ‘testfile.txt’ en la matriz ‘líneas’. A continuación, el código itera sobre la matriz de «líneas» y divide cada línea en elementos usando los comandos «IFS» y «leer».

Después de eso, almacena los elementos en la matriz 2D ‘matriz’ y luego usa el comando de lectura para dividir cada línea en elementos. Ahora cada elemento se asigna al elemento correspondiente en la matriz ‘matriz’ y, finalmente, se imprimen los contenidos de la matriz ‘matriz’ utilizando bucles for anidados.

Conclusión

El comando ‘readarray’ facilita la manipulación de grandes cantidades de datos en scripts de Bash. Siguiendo los ejemplos proporcionados en este artículo, puede comenzar a usar ‘readarray’ en sus propios scripts de Bash para leer líneas de archivos y procesarlos en matrices 2D.

Publicado en Unix - Linux | Deja un comentario

SCRIPT – Métodos de Ordenamiento en Bash.-

Si bien es cierto, Bash es programa usado principalmente para interpretar órdenes que deberán actuar directamente sobre el sistema operativo que lo soporte como es el caso de UNIX. La sintaxis de órdenes de bash está compuesta por ideas que fueron tomadas de Korn Shell (ksh) y el C Shell (csh) y fue de cierta manera enriquecida gracias a la variedad de sentencias heredadas de sus predecesores.

El realizar a manera de práctica e introducción a Bash los métodos de ordenamiento más comunes que se suelen implementar al aprender un lenguaje de programación, sirve exclusivamente para aprender el funcionamiento de las estructuras repetitivas y de flujo, arreglos, operaciones lógicas y aritméticas y sentencias que son básicas para poder involucrarse en la programación en bash, el cual, posteriormente debería ser llevada a una dimensión real realizando scripts que permitirán la automatización de tareas recurrentes que realizamos dentro del sistema operativo como operaciones con ficheros, procesos, comandos, etc.

A continuación, se detallan los métodos de ordenamiento:

1.- Ordenamiento de Burbuja.

El método de ordenamiento burbuja consiste en comparar cada elemento de la estructura con el siguiente e intercambiándolos si corresponde. El proceso se repite hasta que la estructura esté ordenada. El orden se establece de acuerdo con la clave y la estructura tiene que tener acceso directo a sus componentes.

2.- Ordenamiento Shell.-

El método de ordenamiento Shell consiste en dividir el arreglo (o la lista de elementos) en intervalos (o bloques) de varios elementos para organizarlos después por medio del ordenamiento de inserción directa. El proceso se repite, pero con intervalos cada vez más pequeños, de tal manera que al final, el ordenamiento se haga en un intervalo de una sola posición, similar al ordenamiento por inserción directa, la diferencia entre ambos es qué, al final, en el método ShellSu nombre proviene de su creador, Donald Shell, y no tiene que ver en la forma como funciona el algoritmo. los elementos ya están casi ordenados.

3.-  Ordenamiento Quicksort.-

El método Quick Sort es actualmente el más eficiente y veloz de los métodos de ordenación interna. Es también conocido con el nombre del método rápido y de ordenamiento por partición.

Este método es una mejora sustancial del método de intercambio directo y recibe el nombre de Quick Sort, por la velocidad con la que ordena los elementos del arreglo.

Quicksort es un algoritmo basado en la técnica de divide y vencerás, que permite, en promedio, ordenar n elementos en un tiempo proporcional a n log n.

Quicksort es actualmente el más eficiente y veloz de los métodos de ordenación interna.

Este método fue creado por el científico británico Charles Antony Richard Hoare, también conocido como Tony Hoare en 1960, su algoritmo Quicksort es el algoritmo de ordenamiento más ampliamente utilizado en el mundo.

4.- Ordenamiento por Inserción Directa. –

El método de ordenación por inserción directa consiste en recorrer todo el array comenzando desde el segundo elemento hasta el final. Para cada elemento, se trata de colocarlo en el lugar correcto entre todos los elementos anteriores a él o sea entre los elementos a su izquierda en el array.

Dada una posición actual p, el algoritmo se basa en que los elementos A[0], A[1], …, A[p-1] ya están ordenados.

En el peor de los casos, el tiempo de ejecución en O(n2).

En el mejor caso (cuando el array ya estaba ordenado), el tiempo de ejecución de este método de ordenamiento es O(n).

El caso medio dependerá de cómo están inicialmente distribuidos los elementos. Cuanto más ordenada esté inicialmente más se acerca a O(n) y cuanto más desordenada, más se acerca a O(n2).

El peor caso el método de inserción directa es igual que en los métodos de burbuja y selección, pero el mejor caso podemos tener ahorros en tiempo de ejecución.

5.- Ordenamiento por Inserción Binaria. –

El ordenamiento binario es un algoritmo de ordenación de tipo comparación. Es una modificación del algoritmo de ordenamiento por inserción. En este algoritmo, también mantenemos una submatriz ordenada y otra sin ordenar. La única diferencia es que encontramos la posición correcta de un elemento utilizando la búsqueda binaria en lugar de la búsqueda lineal. Esto ayuda a acelerar el algoritmo de ordenación reduciendo el número de comparaciones necesarias.

6.- Ordenamiento por Selección. –

Este algoritmo mejora ligeramente el algoritmo de la burbuja. En el caso de tener que ordenar un vector de enteros, esta mejora no es muy sustancial, pero cuando hay que ordenar un vector de estructuras más complejas, la operación de intercambiar los elementos sería más costosa en este caso.

Publicado en Unix - Linux | Deja un comentario

BASH – Script para mostrar peticiones de logs de apache en rangos (By Alquimista).-

Si es necesario ver en que rangos de horas han habido peticiones al minuto se puede usar este script. Solo funciona en el caso de ser logs de apache.

Publicado en Unix - Linux | Deja un comentario

BASH- Script que envie alerta por correo, cuando un Directorio supere el 90% de uso de disco.

Publicado en Unix - Linux | Deja un comentario

BASH – Script para rotar archivos de log, comprimir todos los archivos con antiguedad mayor a x dias.-

Publicado en Unix - Linux | Deja un comentario

BASH – Script para encontrar el número menor y el mayor en una matriz (arreglo).-

Al ejecutar este script obtendremos el siguiente resultado :

Publicado en Unix - Linux | Deja un comentario

BASH – Matrices asociativas en scripts de Shell.

En Bash, una matriz asociativa es una colección de pares clave-valor, donde cada clave es única y se puede acceder a cada valor usando su clave correspondiente. Para crear una matriz asociativa en Bash, debe usar la siguiente sintaxis:

El comando declare se usa para definir la variable como una matriz asociativa, y la opción -A se usa para especificar que la matriz es asociativa. Para agregar un elemento a una matriz asociativa en Bash, debe usar la siguiente sintaxis:

Aquí [clave] es la clave del elemento, y es el valor asociado con la clave, aquí hay un ejemplo de cómo crear y agregar elementos a una matriz asociativa en Bash:

Aquí, he creado una matriz asociativa denominada coches con tres elementos, cada uno de los cuales contiene el modelo de coche respectivo del fabricante correspondiente. Como ejemplo de cómo obtener el valor de un elemento en una matriz asociativa en Bash, aquí se muestra cómo recuperar la clave de un elemento en una matriz asociativa:

Se puede usar un bucle for para iterar repetidamente a través de todas las claves en una matriz asociativa. Aquí hay un ejemplo en Bash que muestra cómo hacer esto:

Aquí he usado la sintaxis $ {!cars[@]} para obtener todas las claves en la matriz asociativa y luego usé un ciclo for para iterar sobre todas las claves e imprimir los valores correspondientes. Las matrices asociativas son una estructura de datos poderosa que le permite almacenar pares clave-valor en Bash. Puede crear una matriz asociativa usando la sintaxis declare -A, agregarle elementos usando la sintaxis array[key]=value y acceder a los elementos usando sus claves correspondientes. Las matrices asociativas pueden ser útiles para organizar y manipular datos en sus scripts de Bash.

Publicado en Unix - Linux | Deja un comentario

Script – Declarar una matriz bidimensional mediante una matriz asociativa en Bash.-

Este método es un poco complejo. Este método discutirá una matriz especial de secuencias de comandos Bash denominada matriz asociativa.

Una matriz asociativa es una matriz especial que puede almacenar un valor de cadena como clave o índice. Es similar a los otros lenguajes de programación.

La sintaxis general para declarar una matriz asociativa es declare -A ArrayName.

Nuestro ejemplo a continuación creará una matriz 2D que contiene cinco filas y seis columnas. A continuación se muestra el código de nuestro ejemplo.

En el ejemplo anterior, declaramos una matriz asociativa llamada Array2D.

Después de eso, creamos dos variables y les asignamos un valor entero. Este valor entero especifica el número de filas y columnas.

Luego creamos un ciclo anidado que llenó la matriz con el número aleatorio.

Ahora hemos terminado de declarar y organizar la matriz. Es hora de ver cómo se ve nuestra matriz 2D.

Lo hacemos usando algunos bucles, como se ve en el código. Cuando ejecute el script anterior, verá un resultado como el siguiente.

Publicado en Unix - Linux | Deja un comentario

Script – Matriz multidimensional en Bash.-

Una matriz multidimensional es un elemento muy importante para cualquier programa. Se utiliza principalmente para crear una vista de tabla de los datos y para muchos otros fines.

Este es el método más básico para crear una matriz multidimensional. En nuestro ejemplo a continuación, crearemos una matriz bidimensional muy básica.

A continuación, se muestra el código de nuestro ejemplo.

El código anterior muestra que declaramos dos matrices diferentes llamadas ArrayOfArray_1 y ArrayOfArray_2. Después de eso, declaramos nuestra matriz principal, cuyo elemento son estas dos matrices que declaramos recientemente.

Luego calculamos la longitud de la matriz para un bucle. Dentro del bucle, extraemos los datos de estos dos subconjuntos indexando el conjunto principal.

Por último, nos hacemos eco del resultado final. Después de ejecutar el script, obtendrá un resultado como el que se muestra a continuación. Al ejecutar este script, obtendremos lo siguiente :

Publicado en Unix - Linux | Deja un comentario

Script – Pasar un array como argumento de una función en Bash.-

O también puede ser, pasarselo por referencia. Es más entendible :

Al ejecutarlo obtendriamos lo siguiente :

De todas maneras, en ninguno de los casos le pasas el array como parametro. En el primer SCRIPT, desempaquetas el array enfrente de tu función, y le pasas los elementos separados por un espacio; en el segundo SCRIPT, le pasas el nombre de la variable; ya adentro, el nombre se expande y se le referencia a esa otra variable externa para que pueda ser manipulada indirectamente.

Publicado en Unix - Linux | Deja un comentario

BASH – Matemáticas para tus scripts en BashBASH.-

Publicado en Unix - Linux | Deja un comentario

BASH – Plugin NAGIOS «monitoreo de procesos» (Tips para NagiosQL).

En NagiosQL, al definir un servicio a monitorear, especificamente al ingresar un argumento, no permite poner espacios en blanco. Esto da un error al ejecutar el proceso, ya que al encontrar espacios en blanco, asume que es un nuevo argumento. Para solucionar esto se debe definir uno o varios caracteres que indicaran que corresponde a un espacio en blanco y luego en el SCRIPTS ubicado en el equipo a monitorear. Para este ejemplo, definire que la cadena «-b-» corresponde a un espacio en blanco. Luego el script ubicado en el servidor a monitorear, procede a transformar la cadena (proceso) y pone los espacios en blanco donde corresponde.

El siguiente SCRIPT puede utilizarse para monitorear cualquier proceso que este corriendo en un servidor. Utiliza 3 argumentos, el proceso a monitorear, el usuario con que corre el proceso y el minomo y maximo de procesos que corren simultaneamente (Formato min:max) :

Publicado en Unix - Linux | Deja un comentario

BASH – Ejecución en paralelo en Bash.-

El procesamiento en paralelo en Bash se refiere a la ejecución simultánea de múltiples tareas o comandos en un script de Bash. Esto permite aprovechar al máximo los recursos disponibles en un sistema y puede acelerar considerablemente la ejecución de un programa o script.

Hay varias formas de lograr el procesamiento en paralelo en Bash. Una de las formas más comunes es utilizando subprocesos en segundo plano (background processes) y el comando wait para esperar a que todos los subprocesos terminen antes de continuar con el script principal.

Aquí hay un ejemplo simple que muestra cómo ejecutar múltiples comandos en paralelo usando subprocesos en segundo plano,

Es importante tener en cuenta que el número de subprocesos en paralelo que se pueden ejecutar al mismo tiempo puede estar limitado por el sistema operativo y los recursos disponibles en el sistema. Además, el procesamiento en paralelo puede introducir complejidad adicional debido a posibles problemas de concurrencia, como la competencia por recursos compartidos. Por lo tanto, es importante diseñar y probar cuidadosamente el uso de procesamiento en paralelo en un script de Bash.

Un ejemplo

Supongamos que tienes una lista de URLs de sitios web y deseas extraer el título de cada página para realizar un análisis posterior. En lugar de procesar cada URL secuencialmente, puedes aprovechar el procesamiento en paralelo para acelerar el proceso. Aquí hay un ejemplo de cómo podrías hacerlo,

Publicado en Unix - Linux | Deja un comentario

Script – Los códigos de color en BASH.

Por si estás programando algun script en bash o necesitar imprimir algun texto en consola de manera especial y no recuerdas cual era la combinación, El siguiente script (color-bash.sh) te imprime una tabla de colores en bash:

Al ejecutar este código, obtendremos el siguiente resultado :

Publicado en Unix - Linux | Deja un comentario

LINUX – Comando GREP ejemplos varios.

Grep (por sus siglas en inglés Globally Search For Regular Expression and Print out) es una herramienta de líneas de comando usada para buscar cadenas de texto y encontrar coincidencias dentro de este. También puede ser utilizada para encontrar una palabra o combinación de palabras dentro de un fichero.

Esta herramienta requiere de dos parámetros básicos como el patrón a buscar y el archivo en el que se realizará la búsqueda. Además, es importante que conozcamos las expresiones regulares, debido a que estos patrones nos permitirán introducir combinaciones y caracteres para mejorar las búsquedas que hagamos. Una expresión regular usualmente es tomada por el comando de una línea de comandos, lee la lista de archivos e imprime las líneas que contienen coincidencias con la expresión regular.

1.- Podemos filtrar únicamente aquellas líneas que contengan números con el siguiente comando:

grep [[:digit:]] /tmp/archivo.txt

2.- Otra funcionalidad interesante es la de buscar varios patrones en uno o varios archivos. Supongamos que tenemos un archivo de texto denominado /tmp/usuarios.txt, que contiene lo siguiente:

Power

Docker

Y quisiéramos buscar dentro del archivo /etc/group aquellas líneas que

contengan las palabras «power» o «docker». Podríamos hacer lo siguiente:

grep -f /tmp/usuarios.txt /etc/group

3.- Este comando filtra, del archivo /etc/passwd, aquellas líneas que incluyan la palabra «root» o «dbus» al principio de la línea.

grep -E «^root|^dbus» /etc/passwd

4.- Buscar los número con 1 o 2 dígitos…

grep -E «^[0-9][0-9]?$» numeros.txt

Si cambiamos por un * aparecerá 0 veces o más veces por lo tanto mostrara todos los números.

$ grep -E «^[0-9][0-9]*$» numeros.txt

Podemos decir que los primeros números sean del 0 al 9 y los segundos del 0 al 5 por ejemplo. Eso excluirá los 2°, 3° y 4° dígito superior a 5 …

$ grep -E «^[0-9][0-5]*$» numeros.txt

Determinar el número exacto de veces que deseamos que se repita el rango.

$ grep -E «^[0-9]{3}$» numeros.txt

144

233

Especificamos un rango de veces. Por ejemplo los números que contengan 2 a 4 veces.

$ grep -E «^[0-9]{2,4}$» numeros.txt

55

89

144

987

1597

6765

Agrupar expresiones.

Si queremos los números de 1 dígito y los de 3 dígitos, podemos usar dos expresiones regulares dentro de grep con la opción -e por ejemplo…

$ grep -E -e «^[0-9][0-9][0-9]$» -e «^[0-9]$» numeros.txt

1

1

2

3

5

8

144

987

Pero podemos agrupar ésta opción …

$ grep -E  «^[0-9]([0-9][0-9])?$» numeros.txt

1

5

8

377

5.- Buscar una fecha.

grep -E [0-9]{2}/[0-9]{2}/[0-9]{4} prueba.txt

6.- Buscra una hora :

grep -E [0-9]{2}:[0-9]{2}:[0-9]{2} prueba.txt

6.- En el siguiente ejemplo, buscamos todas las apariciones de las palabras fatal, error y critical en el archivo de registro :

grep ‘fatal\|error\|critical’ /var/log/nginx/error.log

7.- Modosilencioso en un if :

if grep -q PATTERN filename

 then

 echo pattern found

 else

 echo pattern not found

 fi

8.- Sacar 2 lineas por encima y 2 lineas por debajo del output :

Cat /etc/passwd | grep -i “ROOT” -C 2

9.- Si al inicio de la salida del comando quieren añadir el nombre del fichero en que se halla la línea mostrada en pantalla deberán usar la opción -H del siguiente modo:

 grep -H -F ‘the’ .bashrc

10.- Pero si queremos obtener únicamente aquellas líneas cuyo único contenido sea la palabra blanco añadiremos la opción -x del siguiente modo:

grep -w -x «blanco» /home/joan/opciones.txt

11.- Con él podemos buscar, por ejemplo, secuencias de varios números seguidos que empiecen con «:».

grep -E ‘:[0-9]+’ regex

12.- Primero vamos a buscar todas las secuencias de cuatro dígitos que haya:

grep ‘[0-9]\{4\}’ regex

13.- Ahora el otro ejemplo con las llaves. Supongamos que queremos encontrar palabras que tengan entre 3 y 6 letras minúsculas. Podríamos hacer lo siguiente:

grep ‘[a-z]\{3,6\}’ regex

14.- Extraer la lista de direcciones de correo electrónico de un archivo:

grep -Eio ‘[a-z0-9._-]+@[a-z0-9.-]+[a-z]{2,4}’ fichero.txt

15.- El siguiente comando extraerá todos los enlaces de un archivo

grep –Eoi ‘<a[^>]+>.*</a>’ filename

16.- Buscar en el archivo /etc/group todas las líneas que empiezan por m.

grep ‘^m’ /etc/group

Texto que acab en “a” :

grep -E ‘a$’ <<<«abracadabra»

17.- Todas las líneas que no contengan ninguno de los siguientes caracteres: sawgtfixkgts.

grep -v «[sawgtfixk]» /usr/share/hunspell/en_US.dic

18.- Todas las líneas que comiencen con 3 letras cualquieras y la palabra dig.

grep «^…dig» /usr/share/hunspell/en_US.dic

19.- Todas las líneas que terminen al menos en una e.

grep -E «e+$» /usr/share/hunspell/en_US.dic

20.- Todas las líneas que contengan una de las siguientes palabras: org, kay o tuna.

grep -E «org|kay|tuna» /usr/share/hunspell/en_US.dic

21.- Cantidad de líneas que comiencen con una o ninguna c seguida de la cadena ati.

grep -cE «^c?ati» /usr/share/hunspell/en_US.dic

22.- Vamos con cosas un poco más complicadas. El carácter «+» empareja con el carácter que aparece a su izquierda repetido al menos una vez. Este carácter sólo está disponible con las expresiones regulares extendidas. Con él podemos buscar, por ejemplo, secuencias de varios números seguidos que empiecen con «:».

grep -E ‘:[0-9]+’ regex

23.- Buscar todas las secuencias de cuatro dígitos que haya:

grep ‘[0-9]\{4\}’ regex    (Expresión regular básica)

grep -E ‘[0-9]{4}’ regex    (Expresión regular extendida)

24.- Supongamos que queremos encontrar palabras que tengan entre 3 y 6 letras minúsculas. Podríamos hacer lo siguiente:

grep ‘[a-z]\{3,6\}’ regex

No es lo que se desea, ya que la expresión regular encuentra las letras dentro de otras palabras que son más largas. Esto lo podría solucionar :

grep ‘\<[a-z]\{3,6\}\>’ regex

25.- imprimir todas las líneas que no empiezan por m.

grep -v ‘^m’ /etc/group

26.- Entre una «a» y la siguiente puede haber hasta dos caracteres:

grep -E ‘^(?a..?)+a?$’ <<<«abracadabra»

27.- El texto contiene al menos un carácter cualquier

grep -E ‘.’ <<<«abracadabra»

28.- El texto contiene un punto

grep -E ‘\.’ <<<«abracadabra»

29.- Comienza el texto por una letra mayúscula

grep -E ‘^[A-Z]’ <<<«Pepe Gotera y Otilio»

30.- Hay alguna palabra que empieze por «o»

grep -E ‘\b[[=o=]]’ <<<«Pepe Gotera y Otilio»

31.- El texto empieza y acaba con los mismos caracteres

grep -E ‘^(?.+).*\1$’ <<<«abracadabra»

32.- Seleccionar una frase si no contiene la palabra Pepe:

grep -P ‘^((?!Pepe).)*$’ <<<«abracadabra»

33.- Muestra todas las líneas que tengan un numero de telefono con extension (letra x o X seguido de 4 digitos) :

grep «[xX][[:digit:]]\{4\}» ejemplos/grepdata.txt

34.- Muestra todas las lineas que comiencen por 3 digitos y un espacio (utilizad \{\}).

grep «^[[:digit:]]\{3\} » ejemplos/grepdata.txt

35.- Muestra todas las lineas que contengan un año (suponed que es despues del 2000).

grep «2[[:digit:]]\{3\} » ejemplos/grepdata.txt

36.- Para generar todas las líneas en «/ usr / dict / words» que tengan exactamente tres caracteres de ancho, escriba:

grep ’ˆ…$’ /usr/dictar/palabras

37.- Para generar todas las líneas en «/ usr / dict / words» que tengan exactamente doce caracteres de ancho, escriba:

grep ’ˆ.\{22,\}$’ /usr/dictar/palabras

38.- Que las lineas comiencen por 2, 4 o 5 :

grep -P ‘^[245]\s+’ /tmp/grep_file

39.- Buscar palabras de 5 caracteres en que la tercera letra sea una “j” y la ultima una “r” :

grep -i ‘^..j.r$’ /usr/share/dict/words

40 .- Las líneas que comiencen por una letra MAYUSCULA :

grep -h ‘^[A-Z]’ dirlist*.txt

41 .- Las líneas que comiencen por una letra Mayúscula, Minúscula o Numero :

grep -h ‘^[A-Za-z0-9]’ dirlist*.txt

Publicado en Unix - Linux | Deja un comentario