Eliminar líneas en blanco con grep

Resuelto node ninja asked hace 14 años • 18 respuestas

Lo intenté grep -v '^$'en Linux y no funcionó. Este archivo proviene de un sistema de archivos de Windows.

node ninja avatar Aug 08 '10 07:08 node ninja
Aceptado

Pruebe lo siguiente:

grep -v -e '^$' foo.txt

La -eopció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\nfinales 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
ars avatar Aug 08 '2010 00:08 ars

Mantenlo simple.

grep . filename.txt
Frej Connolly avatar Dec 28 '2015 11:12 Frej Connolly

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"
ghostdog74 avatar Aug 08 '2010 01:08 ghostdog74
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

Sepero avatar Dec 07 '2012 20:12 Sepero