Eliminar líneas en blanco con grep
Lo intenté grep -v '^$'
en Linux y no funcionó. Este archivo proviene de un sistema de archivos de Windows.
Pruebe lo siguiente:
grep -v -e '^$' foo.txt
La -e
opción permite la coincidencia de patrones de expresiones regulares.
Las comillas simples ^$
hacen que funcione para Cshell. Otros shells estarán contentos con comillas simples o dobles.
ACTUALIZACIÓN: Esto funciona para mí para un archivo con líneas en blanco o "todos los espacios en blanco" (como líneas de Windows con \r\n
finales de línea de estilo), mientras que lo anterior solo elimina archivos con líneas en blanco y finales de línea de estilo Unix:
grep -v -e '^[[:space:]]*$' foo.txt
Mantenlo simple.
grep . filename.txt
Usar:
$ dos2unix file
$ grep -v "^$" file
O simplemente awk:
awk 'NF' file
Si no tiene dos2unix, puede utilizar herramientas como tr :
tr -d '\r' < "$file" > t ; mv t "$file"
grep -v "^[[:space:]]*$"
The -v makes it print lines that do not completely match
===Each part explained===
^ match start of line
[[:space:]] match whitespace- spaces, tabs, carriage returns, etc.
* previous match (whitespace) may exist from 0 to infinite times
$ match end of line
Ejecutando el código-
$ echo "
> hello
>
> ok" |
> grep -v "^[[:space:]]*$"
hello
ok
Para comprender más sobre cómo y por qué funciona esto, recomiendo leer sobre expresiones regulares. http://www.regular-expressions.info/tutorial.html