tutorial_de_sed

Diferencias

Muestra las diferencias entre dos versiones de la página.

Enlace a la vista de comparación

Próxima revisión
Revisión previa
tutorial_de_sed [2021/06/14 02:42] – creado perontutorial_de_sed [2022/07/08 23:04] (actual) peron
Línea 1: Línea 1:
-¿Cómo uso el comando sed en Texto-plano?+====== ¿Cómo uso el comando sed en Texto-plano? ======
  
-Puede sonar extraño, pero el comando sed es realmente un editor de texto sin interfaz alguna. Estaba pensado para el uso de terminales teletipo. Sin mebargo, podrás utilizarlo desde tu terminal remota y a través de tu intérprete de comandos de texto-plano.xyz para manupular texto, tanto en ficheros como con cadenas. ¡Con este tutorial aprenderás a dominar su inusitado poder!+ 
 +Puede sonar extraño, pero [[sed]] es realmente un editor de texto sin interfaz alguna. Estaba pensado para el uso de terminales teletipo. Sin mebargo, podrás utilizarlo desde tu terminal remota y a través de tu intérprete de comandos de texto-plano.xyz para manupular texto, tanto en ficheros como con cadenas. ¡Con este tutorial aprenderás a dominar su inusitado poder!
 El Poder de sed El Poder de sed
  
Línea 31: Línea 32:
 Si bien las sustituciones son probablemnete el empleo mas común que se hace de sed, es conveniente también saber cómo seleccionar y hacer coincidir texto. Si bien las sustituciones son probablemnete el empleo mas común que se hace de sed, es conveniente también saber cómo seleccionar y hacer coincidir texto.
  
-=== Seleccionar Texto ===+==== Seleccionar Texto ====
  
 Utiliza un fichero de texto para nuestro ejemplo. Usa uno que contiene un poema gauchesco décimas de Martín Castro, "Hachando los Alambrados". Lo podrán descargar con el comando: Utiliza un fichero de texto para nuestro ejemplo. Usa uno que contiene un poema gauchesco décimas de Martín Castro, "Hachando los Alambrados". Lo podrán descargar con el comando:
Línea 43: Línea 44:
 less hachando.txt less hachando.txt
  
-Para seleccionar algunas líneas del finchero, proveemos la línea inicial y la línea final del rango de selección. Si usamos un número aislado, sólo seleccionaremos dicha línea.+Para seleccionar algunas líneas del fichero, proveemos la línea inicial y la línea final del rango de selección. Si usamos un número aislado, sólo seleccionaremos dicha línea.
  
 Para extraer las diez líneas que componen la primer décima, ingresa este comando: Para extraer las diez líneas que componen la primer décima, ingresa este comando:
Línea 51: Línea 52:
 </file> </file>
  
-Observa la coma entre 3 y 12. La p significa "presenta las líneas coincidentes". Si actuase por defecto, sed presentaría todas las líneas. Veríamos todo el texto en el fichero, y las líneas coincidentes resultarían impresas dos veces (repetidas). Para impedirlo, emplea la opción -n ("sin salida") para suprimir todas las líneas no coincidente.+Observa la coma entre 3 y 12. La ''p'' significa "presenta las líneas coincidentes". Si actuase por defecto, sed presentaría todas las líneas. Veríamos todo el texto en el fichero, y las líneas coincidentes resultarían impresas dos veces (repetidas). Para impedirlo, emplea la opción ''-n'' ("sin salida") para suprimir todas las líneas no coincidente.
  
 Ahora cambia los números de línea de modo que podamos seleccionar un verso diferente, como se indica: Ahora cambia los números de línea de modo que podamos seleccionar un verso diferente, como se indica:
Línea 59: Línea 60:
 </file> </file>
  
-Puedes usar la opción -e ("expresión") para realizar selecciones múltiples. Si usas dos expresiones, podrás seleccionar dos versos, tal como:+Puedes usar la opción ''-e'' ("expresión") para realizar selecciones múltiples. Si usas dos expresiones, podrás seleccionar dos versos, tal como:
  
 <file bash> <file bash>
Línea 71: Línea 72:
 </file> </file>
  
-También puedes escoger una línea de comienzo e indicarle a sed que avance a lo largo del fichero e imprima las líneas alternadamente, cada cinco líneas, o bien que saltee un número dado de líneas. El comando es similar a aquelos que empleamos anteriormente para seleccionar un rango. Para ello debes utilizar un tilde (~) en lugar de una , para separar los números.+También puedes escoger una línea de comienzo e indicarle a sed que avance a lo largo del fichero e imprima las líneas alternadamente, cada cinco líneas, o bien que saltee un número dado de líneas. El comando es similar a aquellos que empleamos anteriormente para seleccionar un rango. Para ello debes utilizar un tilde (''~'') en lugar de una , para separar los números.
  
 El primer número indicará el comienzo de la línea. El segundo número le indicará a sed qué líneas luego de la línea de comienzo deseas ver. El número 2 significa cada segunda línea, 3 significa cada tercer línea, y así. El primer número indicará el comienzo de la línea. El segundo número le indicará a sed qué líneas luego de la línea de comienzo deseas ver. El número 2 significa cada segunda línea, 3 significa cada tercer línea, y así.
Línea 83: Línea 84:
 Normalmente no se conoce con precisión dónde se localiza exactamente un texto buscado, lo que implica que suele ser imposible proveer los números de línea. Sin embargo, podrás usar sed para seleccionar las líneas que contienen la cadena de texto que buscas. Por ejemplo, prueba extraer todas las líneas que comienzan con "Y". Normalmente no se conoce con precisión dónde se localiza exactamente un texto buscado, lo que implica que suele ser imposible proveer los números de línea. Sin embargo, podrás usar sed para seleccionar las líneas que contienen la cadena de texto que buscas. Por ejemplo, prueba extraer todas las líneas que comienzan con "Y".
  
-El caret (^) representa el comienzo de una línea. Deliminta tu término a buscar en barras (/). También incluirás un espacio luego de "Y", de manera tal que las palabras como "Yo" no aparecerán en el resultado.+El circunflejo (''^'') representa el comienzo de una línea. Delimita tu término a buscar en barras (/). También incluirás un espacio luego de "Y", de manera tal que las palabras como "Yo" no aparecerán en el resultado.
  
-Al leer por primera ver guiones que incluyen sed, no suele resultar obvio. Recordemos que en los comandos anteriores expliqué que /p significa "presentar", o bien "imprimir". Sin embargo, ahora una barra la antecede, de esta manera:+Al leer por primera ver guiones que incluyen sed, no suele resultar obvio. Recordemos que en los comandos anteriores expliqué que ''/p'' significa "presentar", o bien "imprimir". Sin embargo, ahora una barra la antecede, de esta manera:
  
 <file bash> <file bash>
Línea 93: Línea 94:
 Como resultado, quince líneas que comienzan con "y" serán extraídas del fichero y presentadas en la terminal. Como resultado, quince líneas que comienzan con "y" serán extraídas del fichero y presentadas en la terminal.
  
-=== Realizar Sustiticiones ===+==== Realizar Sustiticiones ====
  
 En nuestro primer ejemplo, expuse el primer formato básico para usar la substitución en sed: En nuestro primer ejemplo, expuse el primer formato básico para usar la substitución en sed:
Línea 101: Línea 102:
 </file> </file>
  
-La s indica a sed que lo que viene a continuación es una sustitución lineal. La primer cadena consistirá en la cadena a buscar, mientras que la segunda cadena será el contenido quiere reemplazar. Por supuesto, como sucede en BSD, el demonio está en los detalles.+La ''s'' indica a sed que lo que viene a continuación es una sustitución lineal. La primer cadena consistirá en la cadena a buscar, mientras que la segunda cadena será el contenido quiere reemplazar. Por supuesto, como sucede en BSD, el demonio está en los detalles.
  
 Ingresa entonces el siguiente comando para cambiar todas las apariciones de la cadena "donde" a "ande", y le daremos a Serapio una voz más pampeana: Ingresa entonces el siguiente comando para cambiar todas las apariciones de la cadena "donde" a "ande", y le daremos a Serapio una voz más pampeana:
Línea 109: Línea 110:
 </file> </file>
  
-En la primer línea, sólo se cambiará la segunda ocurrencia de "donde". Eso es así porque sed se detiene luego de encontrar la primer coincidencia por cada línea. Si queremos realizar una búsqueda global - tal que se procesen todas las coincidencias existentes en cada línea del fichero, debemos agregar un modificador g, de la siguiente manera:+En la primer línea, sólo se cambiará la segunda ocurrencia de "donde". Eso es así porque sed se detiene luego de encontrar la primer coincidencia por cada línea. Si queremos realizar una búsqueda global - tal que se procesen todas las coincidencias existentes en cada línea del fichero, debemos agregar un modificador ''g'', de la siguiente manera:
  
 <file bash> <file bash>
Línea 117: Línea 118:
 Esto encontrará "donde" y lo reemplazará con "ande". Pero si la palabra es "Donde" sed es sensible a las mayúsculas, y no considerará que dicha instancia sea lo mismo que "donde". Esto encontrará "donde" y lo reemplazará con "ande". Pero si la palabra es "Donde" sed es sensible a las mayúsculas, y no considerará que dicha instancia sea lo mismo que "donde".
  
-Para solucionar esto, ingresaremos el siguiente comando, agregándole una i al final de la expresión que le asigne a la orden insensibilidad a mayúsculas:+Para solucionar esto, ingresaremos el siguiente comando, agregándole una ''i'' al final de la expresión que le asigne a la orden //insensibilidad a mayúsculas//:
  
 <file bash> <file bash>
Línea 125: Línea 126:
 Esto funcionará, pero la mayoría de las veces no querrás activar la insensibilidad a mayúsculas para todo. En tales casos, podrías usar un grupo de expresión regular que agregue insensibilidad de mayúsculas a cadenas específicas. Esto funcionará, pero la mayoría de las veces no querrás activar la insensibilidad a mayúsculas para todo. En tales casos, podrías usar un grupo de expresión regular que agregue insensibilidad de mayúsculas a cadenas específicas.
  
-Por ejemplo, si encierras los caracteres entre corchetes ([]), serán interpretados como "cualquier caracter de esta lista de caracteres".+Por ejemplo, si encierras los caracteres entre corchetes (''[]''), serán interpretados como "cualquier caracter de esta lista de caracteres".
  
 Introduce lo siguiente para incluir "D" y "d" en el grupo a buscar, de forma de asegurar que en la coincidencia entren tanto "Donde" como "donde" (o sea, se haga indistinta si está con minúscula o mayúscula "donde": Introduce lo siguiente para incluir "D" y "d" en el grupo a buscar, de forma de asegurar que en la coincidencia entren tanto "Donde" como "donde" (o sea, se haga indistinta si está con minúscula o mayúscula "donde":
Línea 139: Línea 140:
 </file> </file>
  
-Busca ahora dos espacios y sustitúyelos por uno. Harás esto globalmente de manera que la acción se repita a lo largo de toda la primer línea. Para ser mas claro, la cadena de búsqueda es "espacio, espacio asterisco (*)", y la cadena de sustitución es "espacio". El 3,12 restringe la sustitución a únicamente las diez líneas del fichero que componen el primer verso.+Busca ahora dos espacios y sustitúyelos por uno. Harás esto globalmente de manera que la acción se repita a lo largo de toda la primer línea. Para ser mas claro, la cadena de búsqueda es "espacio, espacio asterisco (''  *'')", y la cadena de sustitución es "espacio". El 3,12 restringe la sustitución a únicamente las diez líneas del fichero que componen el primer verso.
  
 Todo esto tendrá la forma del siguiente comando: Todo esto tendrá la forma del siguiente comando:
Línea 147: Línea 148:
 </file> </file>
  
-¡Excelente! Lo que importa aquí es el patrón de búsqueda. El asterisco (*) representa cero o más del caracter precedente, que es un espacio. por ello, el patrón a buscar hará que sed analice cadenas de un espacio o más.+¡Excelente! Lo que importa aquí es el patrón de búsqueda. El asterisco (''*'') representa cero o más del caracter precedente, que es un espacio. por ello, el patrón a buscar hará que sed analice cadenas de un espacio o más.
  
-Si sustituyes un espacio simple por cualquier secuencia múltiple de espacios, corregirás el fichero a un espaciado regular, con un espacio simple entre cada palabra. En realidad, esto también sustituirá el uso de espacios simples por otro espacio simple igual, y aunque no es adverso en el resultado, enlentecerá la sustitución.+Si sustituyes un espacio simple por cualquier secuencia múltiple de espacios, corregirás el fichero a un espaciado regular, con un espacio simple entre cada palabra. En realidad, esto también sustituirá el uso de espacios simples por otro espacio simple igual, y aunque no es adverso en el resultado, enllentecerá la sustitución.
  
 Si tipeas lo siguiente y reduces el patrón de búsqueda a un espacio simple, se hará inmediatamente evidente la necesidad de incluir los dos espacios: Si tipeas lo siguiente y reduces el patrón de búsqueda a un espacio simple, se hará inmediatamente evidente la necesidad de incluir los dos espacios:
Línea 159: Línea 160:
 Como el asterisco busca cero o más del caracter precedente, interpretará cada caracter que no sea un espacio como un "cero espacio" y le aplicará la sustitución ¡agregando un espacio tras cada caracter!. Como el asterisco busca cero o más del caracter precedente, interpretará cada caracter que no sea un espacio como un "cero espacio" y le aplicará la sustitución ¡agregando un espacio tras cada caracter!.
  
-Sin embargo, si incluyes dos espacios en la cadena de búsqueda, sed deberá encontrar al menos un caracter de espacio antes de aplicar la substitución. Esto asegurará que los caracteres que no son espacioes permanezca inalterados.+Sin embargo, si incluyes dos espacios en la cadena de búsqueda, sed deberá encontrar //al menos// un caracter de espacio antes de aplicar la substitución. Esto asegurará que los caracteres que no son espacios permanezca inalterados.
  
-El texto contiene dos errores. Si ingresas lo siguiente, usando la -e (expresión) que ya has utilizado anteriormente, podrás realizar dos o más sustituciones en simultáneo:+El texto contiene dos errores. Si ingresas lo siguiente, usando la ''-e'' (expresión) que ya has utilizado anteriormente, podrás realizar dos o más sustituciones en simultáneo:
  
 <file bash> <file bash>
Línea 167: Línea 168:
 </file> </file>
  
-Podrás lograr el mismo resultado utilizando un punto y coma (;) para separar ambas expresiones, de la siguiente manera:+Podrás lograr el mismo resultado utilizando un punto y coma ('';'') para separar ambas expresiones, de la siguiente manera:
  
 <file bash> <file bash>
Línea 189: Línea 190:
 Esto te dará el resultado buscado. Esto te dará el resultado buscado.
  
-=== Sustituciones más complejas ===+==== Sustituciones más complejas ====
  
-Démosle un descanso a los alambrados y usemos ahora sed para extraer nombres del fichero /etc/passwd.+Démosle un descanso a los alambrados y usemos ahora sed para extraer nombres del fichero ''/etc/passwd''.
  
-Hay maneras más cortas de hacerlo (que se expondrán luego), pero usemos la forma más compleja para demostrar otro concepto. Cada ítem coincidente en un patrón de búsqueda (llamadas subexpresiones) puede recibir numeraciones (hasta un máximo de nueve ítems). Podrás utilizar dichos números en tus comandos de sed para referenciar subexpresiones específicas.+Hay maneras más cortas de hacerlo (que se expondrán luego), pero usemos la forma más compleja para demostrar otro concepto. Cada ítem coincidente en un patrón de búsqueda (llamadas //subexpresiones//) puede recibir numeraciones (hasta un máximo de nueve ítems). Podrás utilizar dichos números en tus comandos de sed para referenciar subexpresiones específicas.
  
-Debes cerrar las subexpresiones entre paréntesis precedidas con una barra invertida (\) para que esto funcione. De lo contrario las subexpresiones serían interpretadas como un caracter normal.+Debes cerrar las subexpresiones entre paréntesis precedidas con una barra invertida (''\'') para que esto funcione. De lo contrario las subexpresiones serían interpretadas como un caracter normal.
  
 Para hacerlo, tipearás lo siguiente: Para hacerlo, tipearás lo siguiente:
Línea 205: Línea 206:
 Desglosemos esto: Desglosemos esto:
  
-  *     sed 's/: El comando sed y el comienzo de la expresión de sustitución. +  *    ''sed 's/'': El comando sed y el comienzo de la expresión de sustitución. 
-  *     \(: El paréntesis abierto [(] precedido por una barra invertida(\) abre una subexpresión. +  *     ''\('': El paréntesis abierto [(] precedido por una barra invertida(\) abre una subexpresión. 
-  *     [^:]*: La primer subexpresión de la cadena de búsqueda contiene un grupo en corchetes. Cuando se lo usa en un grupo, el caret (^) significa “no”. Un grupo significa que cualquier caracter que no sea dos puntos (:) será aceptado como una coincidencia. +  *     ''[^:]*'': La primer subexpresión de la cadena de búsqueda contiene un grupo en corchetes. Cuando se lo usa en un grupo, el circunflejo (^) significa “no”. Un grupo significa que cualquier carácter que no sea dos puntos (:) será aceptado como una coincidencia. 
-  *     \): El paréntesis cerrado [)precedido por una barra invertida (\). +  *     ''\)'': El paréntesis cerrado ('')'') precedido por una barra invertida (''\''). 
-  *     .*: Esta segunda subexpresión de búsqueda significa "cualquier caracter y cualquier cantidad de ellos"+  *     ''.*'': Esta segunda subexpresión de búsqueda significa "cualquier caracter y cualquier cantidad de ellos"
-  *     /\1: La porción de sustitución de la expresión contiene 1 precedido por una barra invertida (\). Esto representa el texto que coincide con la primera subexpresión. +  *     ''/\1'': La porción de sustitución de la expresión contiene 1 precedido por una barra invertida (''\''). Esto representa el texto que coincide con la primera subexpresión. 
-  *     /': La barra (/) y el apóstrofe (') terminan el comando de sed.+  *    ''/' '': La barra (''/'') y el apóstrofe (''''') terminan el comando de sed.
  
-Lo que todo esto significa es que se buscará cualquier cadena de caracteres que no contienen un caracter de dos puntos (:), las cuales serán la primer instancia de un texto coincidente. Luego, se buscará cualquier cosa en dicha línea, la cual será la segunda instancia del texto coincidente. Se sustituirá la línea entera con el texto que está indicado en la primer subexpresión.+Lo que todo esto significa es que se buscará cualquier cadena de caracteres que no contienen un caracter de dos puntos ('':''), las cuales serán la primer instancia de un texto coincidente. Luego, se buscará cualquier cosa en dicha línea, la cual será la segunda instancia del texto coincidente. Se sustituirá la línea entera con el texto que está indicado en la primer subexpresión.
  
-Cada línea del fichero /etc/passwd contiene con un nombre de usuario terminado por un caracter de dos puntos, y luego se sustituirá dicho valor por la línea entera. De esta forma, habremos aislados los nombre de usuario.+Cada línea del fichero ''/etc/passwd'' contiene con un nombre de usuario terminado por un caracter de dos puntos, y luego se sustituirá dicho valor por la línea entera. De esta forma, habremos aislados los nombre de usuario.
  
 Salida desde Salida desde
  
-A continuación, cerraremos la segunda subexpresión entre paréntesis ("()"), de modo de poder referenciarla por un número también. También reemplazarás \1 con \2. El comando ahora sustituirá la línea entera con todo a partir del primer caracter de dos puntos (:), hasta el final de la línea.+A continuación, cerraremos la segunda subexpresión entre paréntesis (''()''), de modo de poder referenciarla por un número también. También reemplazarás ''\1'' con ''\2''. El comando ahora sustituirá la línea entera con todo a partir del primer caracter de dos puntos ('':''), hasta el final de la línea.
  
 Para ello ingresa: Para ello ingresa:
Línea 229: Línea 230:
 Estos cambios pequeños dan por invertir el significado de todo el comando, por lo cual recibiremos todo excepto los nombres de usuarios. Estos cambios pequeños dan por invertir el significado de todo el comando, por lo cual recibiremos todo excepto los nombres de usuarios.
  
-Ahora, hechemos un vistazo a una forma rápida y simple de hacer lo mismo:+Ahora, echemos un vistazo a una forma rápida y simple de hacer lo mismo:
  
-Nuestro término de busqueda opera a partir del primer caracter de dos puntos (:) hasta el final de la línea. Como nuestra expresión de sustutución está vacía ("//"), no reemplazará el texto coincidente con cadena alguna.+Nuestro término de búsqueda opera a partir del primer caracter de dos puntos ('':'') hasta el final de la línea. Como nuestra expresión de sustutución está vacía (//), no reemplazará el texto coincidente con cadena alguna.
  
-De modo que si tipeamos lo siguiente, quitando todo desde el primer caracter de dos puntos (:) hasta el final de la línea, se logrará el efecto anterior de dejar sólo los nombres de usuario:+De modo que si tipeamos lo siguiente, quitando todo desde el primer caracter de dos puntos ('':'') hasta el final de la línea, se logrará el efecto anterior de dejar sólo los nombres de usuario:
  
 <file bash> <file bash>
Línea 241: Línea 242:
 Ahora miremos un ejemplo en el cual referenciamos la primer y segunda coincidencia el mismo comando. Ahora miremos un ejemplo en el cual referenciamos la primer y segunda coincidencia el mismo comando.
  
-Tenemos un fichero donde comas (,) separan el nombre y el apellido. Deseamos listarlos como "apellido, nombre". Podremos usar cat, como se muestra abajo, para ver qué hay en este fichero:+Tenemos un fichero donde comas ('','') separan el nombre y el apellido. Deseamos listarlos como "apellido, nombre". Podremos usar cat, como se muestra abajo, para ver qué hay en este fichero:
  
 <file bash> <file bash>
Línea 255: Línea 256:
 Se trata de un comando de sustitución como los anteriores, y la cadena de búsqueda es bastante simple. Desglosémoslo: Se trata de un comando de sustitución como los anteriores, y la cadena de búsqueda es bastante simple. Desglosémoslo:
  
-  *     sed 's/: El comando de sustitución normal. +  *     ''sed 's/'': El comando de sustitución normal. 
-  *     ^: Como el caret no está en un grupo ([]), se interpreta como "el comienzo de la línea"+  *     ''^'': Como el circunflejo no está en un grupo ([]), se interpreta como "el comienzo de la línea"
-  *     \(.*\),: La primera subexpresiñon es cualquier cantidad de cualquier caracter. Está entre paŕentesis "()", cada una de las cuales está precedida por una barra invertida "\", de modo que se referenciará por un número. El comando se interpretará como "buscar desde el comienzo de la línea hasta la primer coma ",cualquier cantidad de cualquier caracter." +  *     ''\(.*\),'': La primera subexpresiñon es cualquier cantidad de cualquier caracter. Está entre paŕentesis ''()'', cada una de las cuales está precedida por una barra invertida ''\'', de modo que se referenciará por un número. El comando se interpretará como "buscar desde el comienzo de la línea hasta la primer coma '','' cualquier cantidad de cualquier caracter." 
-  *     \(.*\): La siguiente subexpresión es -nuevamente- cualquier cantidad de cualquier caracter. También está entre paréntesis, "()ambos de los cuales se hayan precedidos por una barra invertida "\", de modo que podemos referenciar nuevamente el texto coincidente por número. +  *     ''\(.*\)'': La siguiente subexpresión es -nuevamente- cualquier cantidad de cualquier caracter. También está entre paréntesis, ''()'' ambos de los cuales se hayan precedidos por una barra invertida ''\'', de modo que podemos referenciar nuevamente el texto coincidente por número. 
-  *     $/: El signo peso ($) representa el fin de la línea y permitirá a nuestra búsqueda continuar hasta el final de la línea. Se usa esto simplemente para presentar aquí el signo peso. Realmente no se necesita, ya que el asterisco (*) haría llegar hasta el final de la lónea en este escenario. La barra (/) completa la búsqueda de la cadena. +  *     ''$/'': El signo peso ($) representa el fin de la línea y permitirá a nuestra búsqueda continuar hasta el final de la línea. Se usa esto simplemente para presentar aquí el signo peso. Realmente no se necesita, ya que el asterisco (''*'') haría llegar hasta el final de la lónea en este escenario. La barra (''/'') completa la búsqueda de la cadena. 
-  *     \2,\1 /g': Como cerramos nuestras dos subexpresiones entre paréntesis, podemos referir a ambas por sus números. Ya que deseamos invertir su órden, las ingresamos como segunda-coincidencia,primera-coincidencia. Los números deben ser precedidos por una barra invertida (\). +  *    ''\2,\1 /g''': Como cerramos nuestras dos subexpresiones entre paréntesis, podemos referir a ambas por sus números. Ya que deseamos invertir su orden, las ingresamos como segunda-coincidencia,primera-coincidencia. Los números deben ser precedidos por una barra invertida (''\''). 
-  *     /g: Esto activa la operación global en cada línea. +  *     ''/g'': Esto activa la operación global en cada línea. 
-  *     participantes.txt: El fichero en el que estamos trabajando.+  *     ''participantes.txt'': El fichero en el que estamos trabajando.
  
-También puedes usar el comando Cortar (c) para sustituir líneas entera que coincidan con la cadena de búsqueda propuesta. Tipearemos lo siguiente para buscar una línea con la palabra "neck" en ella, y la reemplazaremos con una nueva cadena de texto:+También puedes usar el comando Cortar (''c'') para sustituir líneas entera que coincidan con la cadena de búsqueda propuesta. Tipearemos lo siguiente para buscar una línea con la palabra "neck" en ella, y la reemplazaremos con una nueva cadena de texto:
  
 <file bash> <file bash>
Línea 273: Línea 274:
 Insertar Líneas y Texto Insertar Líneas y Texto
  
-También podremos insertar nuevas líneas y texto en nuestro fichero. Para insertar líneas nuevas a continuación de cualquieras que coincidan, usaremos el comando Agregar (a).+También podremos insertar nuevas líneas y texto en nuestro fichero. Para insertar líneas nuevas a continuación de cualquieras que coincidan, usaremos el comando Agregar (''a'').
  
 He aquí el fichero con el que queremos trabajar: He aquí el fichero con el que queremos trabajar:
Línea 289: Línea 290:
 </file> </file>
  
-Tipea lo siguiente e incluye el comando Insertar (i) para insertar la nueva línea por encima de aquellas que contienen el texto coincidente:+Tipea lo siguiente e incluye el comando Insertar (''i'') para insertar la nueva línea por encima de aquellas que contienen el texto coincidente:
  
 <file bash> <file bash>
Línea 295: Línea 296:
 </file> </file>
  
-Podemos usar el caracter et o ampersand ("&"), que representa al texto coincidente original, para agregar una cadena de texto nuevo a la línea coincidente. \1 , \2 y demás, representan las subexpresiones coincidentes.+Podemos usar el caracter et o ampersand (''&''), que representa al texto coincidente original, para agregar una cadena de texto nuevo a la línea coincidente. ''\1'' ''\2'' y demás, representan las subexpresiones coincidentes.
  
 Para agregar texto al comienzo de una línea, se utiliza un comando de sustitución que haga coincidir todo en la línea, combinado con una cláusula de reemplazo que combine nuestro nuevo texto con la línea original. Para agregar texto al comienzo de una línea, se utiliza un comando de sustitución que haga coincidir todo en la línea, combinado con una cláusula de reemplazo que combine nuestro nuevo texto con la línea original.
Línea 311: Línea 312:
 </file> </file>
  
-Si deseas agregar dos, o tres líneas en blanco, puedes usar G;G, G,G,G, y así. +Si deseas agregar dos, o tres líneas en blanco, puedes usar ''G;G,'' ''G,G,G,'' y así. 
-Borrar líneas+====Borrar líneas====
  
-El comando Borrar (d) borra las líneas que coincidan con el patrón de búsqueda, o aquellas líneas especificadas números de líneas o rangos de líneas.+El comando Borrar (''d'') borra las líneas que coincidan con el patrón de búsqueda, o aquellas líneas especificadas números de líneas o rangos de líneas.
  
 Por ejemplo, para borrar la tercer línea, tipearíamos lo siguiente: Por ejemplo, para borrar la tercer línea, tipearíamos lo siguiente:
Línea 342: Línea 343:
 Es una buena política instruir a sed para que cree una copia de respaldo del fichero original antes de ejecutar cualquier comando. Es una buena política instruir a sed para que cree una copia de respaldo del fichero original antes de ejecutar cualquier comando.
  
-Puedes usar la opción En el Lugar (-i) para indicar a sed que escriba los cambios al fichero original, pero si le agregas una extensión de archivo, sed procederá a respaldar el fichero original con dicha extensión. Tendrá el mismo nombre que el fichero original, pero con una nueva extensión.+Puedes usar la opción En el Lugar (''-i'') para indicar a sed que escriba los cambios al fichero original, pero si le agregas una extensión de archivo, sed procederá a respaldar el fichero original con dicha extensión. Tendrá el mismo nombre que el fichero original, pero con una nueva extensión.
  
-Para demostrarlo, busca cualquier línea que contiene la palabra "He" y bórrala. También respaldaremos nuestro fichero original a uno nuevo aplicándole la extensión .BAK.+Para demostrarlo, busca cualquier línea que contiene la palabra "He" y bórrala. También respaldaremos nuestro fichero original a uno nuevo aplicándole la extensión ''.bak''.
  
 Para hacerlo así, ingresa lo siguiente: Para hacerlo así, ingresa lo siguiente:
  • tutorial_de_sed.1623638532.txt.gz
  • Última modificación: 2021/06/14 02:42
  • por peron