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 :

transformer un fichier csv en un autre avec awk


Sujet :

Shell et commandes GNU

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 1
    Points : 2
    Points
    2
    Par défaut transformer un fichier csv en un autre avec awk
    Bonjour à tous,

    J'aimerais écrire un script en awk qui lit un premier csv qui liste les clients où le séparateur est ";" et crée en sortie un deuxième csv qui se compose d'un ensemble de champs différent de celui du premier csv et dont les lignes dépendent du fait que le client est particulier ou bien une société (champ "civility").

    Exemple :
    Fichier csv input :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    "FIRST_NAME";"LAST_NAME";"CIVILITY";"GENDER";"NCLI"
    "Alain";"Bernard";"Monsieur";"M";"1.25265849"
    "Catherine";"Devos";"Madame";"F";"1.25265859"
    "Ines";"lombard";"Mademoiselle";"F";"1.25265837"
    "Groupe";"Automobile";"Societe";;"1.25265839"
    Fichier csv output :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    "FIRST_NAME";"LAST_NAME";"Num_client";"Num_client_societe"
    "Alain";"Bernard";"1.25265849";
    "Catherine";"Devos";"1.25265859";
    "Ines";"lombard";"1.25265837";
    "Groupe";"Automobile";;"1.25265839"
    Donc si le client est particulier, c'est la colonne "Num_client" qui sera rempli par la valeur à partir du premier csv sinon c'est la colonne "Num_client_societe" qui sera remplie.

    Merci de votre aide

  2. #2
    Membre expert Avatar de jabbounet
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2009
    Messages
    1 909
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juin 2009
    Messages : 1 909
    Points : 3 284
    Points
    3 284
    Par défaut
    pas besoin de awk, sed suffit pour le faire.

    Code fichier.sed : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    # Chaines a remplacer dans le fichier.
    s/"CIVILITY";"GENDER";//
    s/"Monsieur";"M";//
    s/"Madame";"M";//
    s/"Mademoiselle";"F";//
    s/"Societe";//

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    sed -f fichier.sed fichier.csv

Discussions similaires

  1. Transformation tableau -> fichier csv avec opération
    Par archibald78 dans le forum Excel
    Réponses: 0
    Dernier message: 03/06/2011, 18h02
  2. Réponses: 29
    Dernier message: 21/10/2008, 17h36
  3. Réponses: 3
    Dernier message: 06/08/2007, 03h44
  4. [XSL] Comment transformer un fichier XML en un autre XML
    Par elzedo dans le forum XSL/XSLT/XPATH
    Réponses: 6
    Dernier message: 16/01/2006, 10h51

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