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 :

Extraction de données d'un fichier csv


Sujet :

Shell et commandes GNU

  1. #1
    Futur Membre du Club
    Inscrit en
    Novembre 2008
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 11
    Points : 8
    Points
    8
    Par défaut Extraction de données d'un fichier csv
    Bonjour à tous,

    Voici mon dilemme, je ne connais rien en développement shell et on me demande d'extraire des données à partir d'un fichier csv sous Unix pour une date donnée.

    Voici les champs contenus dans le fichier csv :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Date;Enchaînement;Titre;Libellé ;calendrier;Heure début;Heure fin;Durée estimée;Durée réelle;"Durée ré-évaluée ou 
    informations complémentaires";Contraintes, dépendances et criticités;
    et voici le contenu du fichier :

    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
    01/12/2010;;;;;;;;;;;
    ;bp_101;"IE001 (4 UT)
    BP_10101 à BP_10104"; INTERFACE ENTRANTE : TOTO => GAGA;SPF;;;;;;"bg00<nn><zz>.bp
    sur bonne ou mauvaise fin de bp_102 (FORMP)";
    ;bp_209;"IE017 (3 UT)
    BP_20901 à BP_20903";INTERFACE ENTRANTE :TOTO => GAGA;SPF;;;;;;"gesiaaaa.bp 
    Exclusif";
     
    02/12/2010;;;;;;;;;;
    ;bp_101;"IE001 (4 UT)
    BP_10101 à BP_10104"; TOTO : GOGO => GAGA;SPF;;;;;;"bg00<nn><zz>.bp
    sur bonne ou mauvaise fin de bp_102 (FORMP)"
    ;bp_209;"IE017 (3 UT)
    BP_20901 à BP_20903";TOTO => GAGA;SPF;;;;;;"gesiaaaa.bp 
    Exclusif"
    Comme on peut le voir, à chaque date correspondent plusieurs traitements (ex : au 02/12/2010 il y a bp_101 et à la ligne du dessous il y a bp_209, à chaque fois précédé d'un champ vide correspondant à une date...)

    Y a-t-il un moyen de créer un shell demandant la date et à partir de la réponse, sortir chaque traitement correspondant ?

    Merci d'avance pour votre aide...

  2. #2
    Membre averti
    Homme Profil pro
    Gérant infopsylon
    Inscrit en
    Juin 2010
    Messages
    215
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : Gérant infopsylon
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2010
    Messages : 215
    Points : 328
    Points
    328
    Par défaut
    Bonjour,

    Oui c'est possible.
    As-tu déjà essayé de faire quelque chose ?

    Ton fichier est-il vraiment séparé en paragraphes ?

    Si c'est la cas, tu devrais t'en sortir avec ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    sed -e '/./{H;$!d;}' -e 'x;/01\/12\/2010/!d;' <ton_fichier>
    En remplaçant les éléments en rouge par ce qui te convient.

    Lilian.

  3. #3
    Futur Membre du Club
    Inscrit en
    Novembre 2008
    Messages
    11
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 11
    Points : 8
    Points
    8
    Par défaut
    Merci,

    On m'a conseillé d'utiliser awk et voici mon script
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    #!/bin/sh
    awk 'BEGIN{printf("Entrez la date : "); getline date < "-"}
    $0 ~ date {f=1}
    f
    /^[0-9]{2}\//{f=0}
    f' toto.csv
    qui donne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $ ./extract.sh
    Entrez la date : 02/12/2010
    02/12/2010;;;;;;;;;;
    => mais pas les actions contenues sous la date, et uniquement pour la date prise en compte par le getline date dans le fichier csv (exemple fichier csv dessous)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    02/12/2010;;;;;;;;;;;
    ;Action_1;; Comment;Comment;;;;;;"File Comment";
    ;Action_2;; Comment;Comment;;;;;;"Exclusif";
    ;Action_3;; Comment;Comment;;;;;;"Not exclusif";
    ;Action_4;; Comment;Comment;;;;;;"Another File Comment";
    ;Action_5;; Comment;Comment;;;;;;"File Comment";
    ;Action_6;; Comment;Comment;;;;;;"File Comment";
    03/12/2010;;;;;;;;;;;
    ;Action_1;; Comment;Comment;;;;;;"File Comment";
    ;Action_2;; Comment;Comment;;;;;;"Exclusif";
    ;Action_3;; Comment;Comment;;;;;;"Not exclusif";
    ;Action_4;; Comment;Comment;;;;;;"Another File Comment";
    ;Action_5;; Comment;Comment;;;;;;"File Comment";
    ;Action_6;; Comment;Comment;;;;;;"File Comment";
    Si quelqu'un voit d'où vient le problème ? Merci

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

Discussions similaires

  1. extraction de données dans un fichier csv
    Par yeddes dans le forum R
    Réponses: 1
    Dernier message: 22/04/2015, 14h23
  2. [2005] Extraction de données depuis un fichier CSV
    Par alaabed dans le forum SSIS
    Réponses: 3
    Dernier message: 22/04/2011, 15h07
  3. [MySQL] Importer les données d'un fichier CSV dans une base de données
    Par joueur dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 12/11/2008, 12h59
  4. Extraction de donnés dans un fichier XML
    Par ANISSS dans le forum XML/XSL et SOAP
    Réponses: 1
    Dernier message: 27/01/2006, 14h16
  5. Extraction de données sur des fichiers excel
    Par iupgeii dans le forum MFC
    Réponses: 3
    Dernier message: 23/01/2004, 14h53

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