Aller au contenu

supprimer les lignes vides dans un fichier

Featured Replies

Posté(e)

Bonjour

j'ai un fichier dans lequel il y a plein de lignes vides intercalées. je voudrais savoir s'il existe une commande qui va me permettre de supprimer les lignes vides.

merci

Posté(e)

sed -i '/^$/d' FICHIER

:)

mais ATTENTION, cela va modifier définitivement ton fichier ...

pour valider avant :

sed '/^$/d' FICHIER

(sans le -i)

Posté(e)

Voilà pareil.

Sinon

grep -vE "^$" FICHIER

Ou avec une super feinte :

grep '.' FICHIER

Et en awk :

awk '/./' FICHIER

Et enfin une version qui supprime lignes vides ET lignes ne contenant que des caractères d'espacement :

grep -Ev "^\s*$" smtp_state.pm

(Fonctionne aussi avec sed et awk)

Posté(e)
  • Auteur

Merci à tous les deux ça fonctionne. avez vous un tutoriel simple avec beaucoup d'exemple pour apprendre awk et sed?

Posté(e)

juste en passant, si tu as plein de lignes vides qui se suivent des fois par paquet de 2 3 ou plus ...

pour aller un poil plus vite tu commence par un coup de "uniq" sur le fichier (ça supprime les lignes identiques redondantes - en supposant qu'il n'y ait que des lignes vides en redondance)

uniq ton_fichier.txt | grep -v ^#

pour continuer la digression, uniq est pas mal aussi pour alléger des opérations mémoires lourdes

si tu as une liste en vrac et que tu veux juste chaque occurence possible, tu fais un "uniq | sort | uniq" ça peut être beaucoup plus rapide qu'un simple "sort | uniq" ... parceque sort n'aura pas à gérer un certain nombre de doublons successifs

(utile par exemple quand tu parse des logs et que tu veux la liste des machines ou process qui en émettent, ou la liste des émetteurs de mail, etc.)

:transpi:

Archivé

Ce sujet est désormais archivé et ne peut plus recevoir de nouvelles réponses.