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

C Discussion :

convertir un fichier csv


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    1
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 1
    Par défaut convertir un fichier csv
    bonjour,

    voila, j'ai un souci:

    j'ai un fichier texte (csv)

    du type:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    1;article;1;codebarre;0;0;;;;;0;;;quantité1;0.00;0.00;0.00;;0;;0;;0;;20.00;0.00;20.00;0.00;0.00;2.09;21.80;41.80;19.60;prix;0.00;-20.00;0.00;19.60;0.00;0.00;-20.00;0.00;19.60;0.00;;;;0.00;0;0;0001;0001;0001;19.60;0001;0.00;11579568;1;0.00;0;0;1;0.00;0;0;;;0;;;;0;0.00;0.00;
    2;article2;1;;codebarre;0;;;;;0;;;quantité2;0.00;0.00;0.00;;0;;0;;0;;8.00;0.00;8.00;0.00;0.00;1.25;2.03;10.03;19.60;prix;0.00;-8.00;0.00;19.60;0.00;0.00;-8.00;0.00;19.60;0.00;;;;0.00;0;0;0001;0001;0001;19.60;0001;0.00;11579568;1;0.00;0;0;1;0.00;0;0;;;0;;;;0;0.00;0.00;
    3;.......
    je souhaite le convertir en fichier txt ayant cette structure:
    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
     
     
    codebarre
    article1
    prix              |
                      | un nombre de fois egal a quantité1
    codebarre         |
    article1          |
    prix
     
    codebarre
    article2
    prix              |
                      | un nombre de fois egal a quantité2
    codebarre         |
    article2          |
    prix
    j'aurais besoin de votre aide , d'avance je vous remercie

  2. #2
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par yohann62_24 Voir le message
    j'ai un fichier texte (csv)

    du type:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    1;article;1;codebarre;0;0;;;;;0;;;quantité1;0.00;0.00;0.00;;0;;0;;0;;20.00;0.00;20.00;0.00;0.00;2.09;21.80;41.80;19.60;prix;0.00;-20.00;0.00;19.60;0.00;0.00;-20.00;0.00;19.60;0.00;;;;0.00;0;0;0001;0001;0001;19.60;0001;0.00;11579568;1;0.00;0;0;1;0.00;0;0;;;0;;;;0;0.00;0.00;
    2;article2;1;;codebarre;0;;;;;0;;;quantité2;0.00;0.00;0.00;;0;;0;;0;;8.00;0.00;8.00;0.00;0.00;1.25;2.03;10.03;19.60;prix;0.00;-8.00;0.00;19.60;0.00;0.00;-8.00;0.00;19.60;0.00;;;;0.00;0;0;0001;0001;0001;19.60;0001;0.00;11579568;1;0.00;0;0;1;0.00;0;0;;;0;;;;0;0.00;0.00;
    3;.......
    je souhaite le convertir en fichier txt ayant cette structure:
    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
     
     
    codebarre
    article1
    prix              |
                      | un nombre de fois egal a quantité1
    codebarre         |
    article1          |
    prix
     
    codebarre
    article2
    prix              |
                      | un nombre de fois egal a quantité2
    codebarre         |
    article2          |
    prix
    j'aurais besoin de votre aide , d'avance je vous remercie
    Je conseille dans un premier temps de définir une structure contenant les éléments désirés. Ensuite, écrire une fonction qui va extraire les informations de chaque ligne. Je recommande un tableau de pointeurs sur char, strtok() ou strtok_r() (POSIX.1) et strdup (POSIX.1). Placer ensuite ces données dans la structure. Certaines conversions devront être faites (strtod() etc.).

    une fois la structure remplie (éventuellement sous la forme d'un tableau ou d'une liste de structures), traiter cet ensemble par une fonction d'affichage.

    C'est un travail assez important, mais pas très difficile. Mais il nécessite de connaitre parfaitement les bases du C.

    Fait de ton mieux et poste ton code.

  3. #3
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par yohann62_24 Voir le message
    bonjour,

    voila, j'ai un souci:

    j'ai un fichier texte (csv)

    du type:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    1;article;1;codebarre;0;0;;;;;0;;;quantité1;0.00;0.00;0.00;;0;;0;;0;;20.00;0.00;20.00;0.00;0.00;2.09;21.80;41.80;19.60;prix;0.00;-20.00;0.00;19.60;0.00;0.00;-20.00;0.00;19.60;0.00;;;;0.00;0;0;0001;0001;0001;19.60;0001;0.00;11579568;1;0.00;0;0;1;0.00;0;0;;;0;;;;0;0.00;0.00;
    2;article2;1;;codebarre;0;;;;;0;;;quantité2;0.00;0.00;0.00;;0;;0;;0;;8.00;0.00;8.00;0.00;0.00;1.25;2.03;10.03;19.60;prix;0.00;-8.00;0.00;19.60;0.00;0.00;-8.00;0.00;19.60;0.00;;;;0.00;0;0;0001;0001;0001;19.60;0001;0.00;11579568;1;0.00;0;0;1;0.00;0;0;;;0;;;;0;0.00;0.00;
    3;.......
    je souhaite le convertir en fichier txt ayant cette structure:
    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
     
     
    codebarre
    article1
    prix              |
                      | un nombre de fois egal a quantité1
    codebarre         |
    article1          |
    prix
     
    codebarre
    article2
    prix              |
                      | un nombre de fois egal a quantité2
    codebarre         |
    article2          |
    prix
    j'aurais besoin de votre aide , d'avance je vous remercie
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Ouvrir fichier 1 en lecture
    Ouvrir fichier 2 en écriture
    TANT QUE lecture ligne fichier1 ok FAIRE
        Décortiquer ligne pour en extraire les infos
        Ecrire les infos dans le fichier 2 sur autant de lignes que nécessaire, en calculant les infos manquantes à partir des infos présentes si nécessaire, en incluant au besoin des boucles d'écriture si le nombre de lignes à écrire dépend d'une info extraite à l'étape d'avant
    FIN TANT QUE
    Fermer fichier 1
    Fermer fichier 2
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

Discussions similaires

  1. Convertir un fichier csv en fichier xls
    Par mond14 dans le forum Shell et commandes GNU
    Réponses: 6
    Dernier message: 27/05/2013, 15h13
  2. Convertir un fichier CSV avec l'interop d'Excel - .Net
    Par bliss190 dans le forum Général Dotnet
    Réponses: 3
    Dernier message: 29/10/2010, 08h12
  3. [XL-2003] Convertir un fichier .csv
    Par chatillon en diois dans le forum Excel
    Réponses: 5
    Dernier message: 25/02/2010, 09h22
  4. Comment faire pour convertir des fichiers csv en série ?
    Par Debutante-Excel dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 31/05/2009, 21h34
  5. convertir un fichier csv en xls
    Par alain47 dans le forum Excel
    Réponses: 2
    Dernier message: 20/04/2009, 11h50

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