linux:bash:sed

Diferències

Ací es mostren les diferències entre la revisió seleccionada i la versió actual de la pàgina.

Enllaç a la visualització de la comparació

Ambdós costats versió prèvia Revisió prèvia
Següent revisió
Revisió prèvia
linux:bash:sed [20/08/2018 23:56] – [ejemplos] matelinux:bash:sed [10/04/2019 00:30] (actual) – [ejemplos avanzados] mate
Línia 21: Línia 21:
     * ''!'' : negar la condición     * ''!'' : negar la condición
     * ''q'' : finalizar procesamiento de fichero     * ''q'' : finalizar procesamiento de fichero
 +<code bash>
 +sed 's/busca/reemplaza/g' /path/to/file(s)
 +</code>
  
 == parámetros == parámetros
Línia 55: Línia 58:
 sed -i "2,$d" distros-deb.txt # de la línea 2 al final</code> sed -i "2,$d" distros-deb.txt # de la línea 2 al final</code>
  
-<code bash></code> +ejemplo docker 
-<code bash></code>+<code bash>sed -i /etc/ssh/sshd_config \ 
 +            -e 's/#PermitRootLogin.*/PermitRootLogin no/' \ 
 +            -e 's/#RSAAuthentication.*/RSAAuthentication yes/' 
 +            -e 's/#PasswordAuthentication.*/PasswordAuthentication no/' 
 +</code> 
 + 
 +== ejemplos avanzados 
 +añadir texto a una línea, respetando el contenido existente (y haciendo match). Uso de subexpresión (backreference) 
 +<code bash>sed -i "1,12s/\(host: \)[^ ]*/\1localhost/" config/database.yml</code> 
 +  * ''-i'' : sobrrescribe el fichero (config/database.yml en este caso) 
 +  * ''1,12'' : sobre ese rango de líneas 
 +  * ''(host: )'' : busca esa cadena, pero además la guarda. En la instrucción ( y ) están escapados <- subexpresión 
 +  * ''[^ ]*'' : cualquier número de caracteres que no sean espacios ?? 
 +  * ''\1 <cadena>'' : recupera el texto guardado en la anterior expresión y le añade <cadena>.. el 1 está escapado! 
 + 
 +insertar línea antes de match, backup del fichero modificado 
 +<code bash> 
 +sed -i.bak '/<\/tomcat-users>/ i\<user username="admin" password="password" roles="admin,manager-gui,admin-gui"/>' /opt/tomcat/conf/tomcat-users.xml 
 +</code> 
 + 
 +=== búsquedas 
 +buscar frases de un texto que tengas 6 palabras (y acaben en algo que no sea una letra): 
 +<code bash>grep -E '^([a-zA-Z]+[^a-zA-Z]+){6}$' frases</code> 
 +  * ''^'' inicio de frase (dentro de corchetes, es negación!) 
 +  * ''(...)'' : subexpresión 
 +  * ''[a-zA-Z]+'' : palabras 
 +  * ''[^a-zA-Z]+'' : y no palabras 
 +  * ''{6}'' : afecta a toda la subexpresión y hace que se repita 6 veces 
 +  * ''$'' : final de frase (línea) 
 + 
 +buscar palíndromos de 7 letras((palabra capicúa))<code bash>grep '^\(.\)\(.\)\(.\).\3\2\1$' /usr/share/dict/words</code> 
 +  * cada grupo de paréntesis hace que ese caracter se guarde para "futuras" referencias. El primer paréntesis se referencia como 1, el segundo... 
 +  * y se recogen esos valores con \3 \2 \1 respectivamente
  • linux/bash/sed.1534834579.txt.gz
  • Darrera modificació: 20/08/2018 23:56
  • per mate