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 :

[sed] Suppressions de ligne d'un fichier à partir d'un tableau passé en paramètre


Sujet :

Shell et commandes GNU

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 5
    Par défaut [sed] Suppressions de ligne d'un fichier à partir d'un tableau passé en paramètre
    Bonjour,

    J'aimerais supprimer les lignes d'un fichier à l'aide de sed, en lui passant en paramètre un tableau contenant les critères de recherche.

    Actuellement je boucle sur un tableau et pour chaque entrée je lance sed en mode delete :

    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
     
    # Importation dans un tableau du fichier contenant les chaînes à rechercher
    filesupp="suppressions.csv"
    if [ -f $filesupp ]
    then
        mapfile TAB_SUPPRESSION < $filesupp
    fi
     
    # Boucle sur le tableau et appel de sed en mode delete pour chaque ligne 
    file="fichieratraiter.csv"
    if [ -f $file ]
    then
        for supp in ${TAB_SUPPRESSION[*]}
        do
            sed -i "/$supp;/d" $file
        done
    fi
    Existe-t-il un moyen d'appeler sed qu'une fois en lui passant le tableau en paramètre ?
    Ou de passer par awk ?

    Merci

  2. #2
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 335
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 335
    Par défaut
    En gros, tu fais un grep -vf suppressions.csv fichieratraiter.csv en plus compliqué avec sed ?

    pour t'aider, il serait bien d'avoir un exemple concret

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 5
    Par défaut
    Merci pour ta réponse, cela semble effectivement beaucoup plus simple et rapide.

    Je viens de tester et cela fonctionne bien mais j'aimerais que la recherche se fasse sur le motif exact contenu dans le fichier des suppressions.
    En effet, je me suis aperçu que des lignes étaient supprimées alors que le motif ne correspond pas exactement.

    Exemple fichier "suppressions.csv" (il ne contient qu'un seul champ)
    U0708
    U5230
    F3690

    Exemple fichier "fichieratraiter.csv" (il contient plusieurs champs séparés par un point-virgule)
    UER;VA;FAC;U0708;2024/04/18;EMP <- A supprimer
    UER;VA;FAC;U0708B;2024/04/18;EMP <- Ligne supprimée à tort
    UER;VA;FAC;U07932;2024/04/18;CE <- Ligne supprimée à tort car commence par U07 ?
    VFR;VA;FAC;S6587;2024/04/18;ADH
    XTZ;RA;OBL;D2301;2024/04/18;SAL
    YZF;RA;OBL;U5230;2024/04/18;CE <- A supprimer
    RSE;IN;OSF;F3690;2024/04/18;SDI <- A supprimer
    RSE;IN;OSF;F3690B;2024/04/18;SDI <- Ligne supprimée à tort

    J'aimerais supprimer les lignes qui correspondent exactement à la chaîne recherchée.

    Merci

  4. #4
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 335
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 335
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -f - fichieratraiter.csv < <(sed 's@.*@/;&;/d@' suppressions.csv )
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    grep -vf - fichieratraiter.csv < <(sed 's@.*@;&;@' suppressions.csv )
    Ici, il ne faut pas que cela soit le premier ou le dernier champs pour que cela fonctionne

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 5
    Par défaut
    Merci pour ton aide, ça fonctionne parfaitement

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

Discussions similaires

  1. Suppression de lignes d'un fichier
    Par griese dans le forum Langage
    Réponses: 18
    Dernier message: 06/12/2006, 14h38
  2. Suppression de lignes dans un fichier texte
    Par Isa31 dans le forum Langage
    Réponses: 16
    Dernier message: 26/01/2006, 20h07
  3. Suppression de lignes dans un fichier sous dos
    Par ducho dans le forum Windows
    Réponses: 2
    Dernier message: 16/05/2005, 10h20
  4. Suppression de lignes dans un fichier
    Par bubu dans le forum Linux
    Réponses: 2
    Dernier message: 13/01/2005, 10h36

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