IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Shell et commandes GNU Discussion :

Supprimer caractère suivant la ligne suivante


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Invité
    Invité(e)
    Par défaut Supprimer caractère suivant la ligne suivante
    Bonjour,

    J'ai un fichier de ce type:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    (blabla,blabla,toto),^M
    (blabla,blabla,tata),^M
    INSERT ...^M
    (blabla,titi),^M
    Je voudrais juste supprimer la virgule en fin de ligne quand elle est devant une ligne commençant par le mot INSERT et rajouter une ligne avant INSERT. Donc obtenir:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    (blabla,blabla,toto),^M
    (blabla,blabla,tata)^M
    ^M
    INSERT ...^M
    (blabla,titi),^M
    Si nécessaire, on peut enlever le ^M (retour chariot windows)
    Je suis sûr que c'est possible de le faire avec sed (et sans doute avec awk) mais je galère vraiment quand il faut gérer plusieurs lignes ...

    Merci d'avance

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    1 946
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 1 946
    Par défaut
    Salut,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $ cat -A brol 
    (blabla,blabla,toto),^M$
    (blabla,blabla,tata),^M$
    INSERT ...^M$
    (blabla,titi),^M$
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $ sed ':z;N;$!bz;s/,\(\r\nINSERT\)/\r\n\1/' brol | cat -A
    (blabla,blabla,toto),^M$
    (blabla,blabla,tata)^M$
    ^M$
    INSERT ...^M$
    (blabla,titi),^M$

  3. #3
    Invité
    Invité(e)
    Par défaut
    Euh? Ca ne fonctionne pas chez moi ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    $ cat -A fichier-test
    (blabla,blabla,toto),^M$
    (blabla,blabla,tata),^M$
    INSERT ...^M$
    (blabla,titi),^M$
     
    $ sed ':z;N;$!bz;s/,\(\r\nINSERT\)/\r\n\1/' fichier-test
    (blabla,blabla,toto),
    (blabla,blabla,tata),
    INSERT ...
    (blabla,titi),
     
    $ sed ':z;N;$!bz;s/,\(\r\nINSERT\)/\r\n\1/' fichier-test | cat -A
    (blabla,blabla,toto),$
    (blabla,blabla,tata),$
    INSERT ...$
    (blabla,titi),$
    Edit: Je dois avoir une config qui me fait perdre les ^M car comme ceci ça fonctionne (j'utilise cygwin)
    J'ai aussi rajouté le g à la fin du sed pour le remplacer à chaque fois dans le fichier

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $ sed ':z;N;$!bz;s/,\(\nINSERT\)/\r\n\1/g' fichier-test
    (blabla,blabla,toto),
    (blabla,blabla,tata)
     
    INSERT ...
    (blabla,titi),

  4. #4
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    1 946
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 1 946
    Par défaut
    Bizarre, tes "^M" ont quand même disparu

    Quel système ? Quel shell ?

    Essaies de remplacer les "\r" par "\x0D" :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed ':z;N;$!bz;s/,\(\x0d\nINSERT\)/\x0d\n\1/'

  5. #5
    Invité
    Invité(e)
    Par défaut
    J'utilise cygwin sous windows. Ca me rappelait quelque chose et je viens de le retrouver (l'option -b)

    Maintenant, c'est parfait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $ sed -b ':z;N;$!bz;s/,\(\r\nINSERT\)/\r\n\1/g' fichier-test | cat -A
    (blabla,blabla,toto),^M$
    (blabla,blabla,tata)^M$
    ^M$
    INSERT ...^M$
    (blabla,titi),^M$

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [11gR2] Supprimer les doublons de lignes suivant quatre colonnes
    Par lcaya dans le forum SQL
    Réponses: 8
    Dernier message: 08/10/2013, 08h19
  2. Supprimer ligne suivant valeur
    Par isarian dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 08/12/2011, 14h14
  3. Réponses: 2
    Dernier message: 27/07/2011, 09h37
  4. [XL-2007] Supprimer plusieurs lignes suivant un test
    Par isarian dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 23/03/2011, 17h47
  5. Réponses: 11
    Dernier message: 05/08/2010, 14h19

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo