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

  1. #1
    Membre à l'essai
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    novembre 2014
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 32
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : novembre 2014
    Messages : 27
    Points : 20
    Points
    20

    Par défaut Extraction des colonnes par leurs noms

    Bonjour,

    Je voudrais extraire des colonnes d'un fichier texte (séparées par des tabulations) par leurs noms plutôt et ne pas par leur numéro de position.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     
    my @fic = <$F1> ;
     
    foreach my $line (@fic)
    {	chomp($line);
    	my @line=split(/\t/,$line);
    print OUT "$line[4]\t$line[20]\t ..........";
    Merci pour votre aide.

  2. #2
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    mai 2012
    Messages
    3 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : mai 2012
    Messages : 3 559
    Points : 12 223
    Points
    12 223
    Billets dans le blog
    1

    Par défaut

    Il suffit de mettre les noms de champs à gauche de l'affectation du split, par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    foreach my $line (@fic) {	
        chomp($line);
        my ($prem, $deuze, $trois) = split /\t/, $line;
        # print OUT $prem, "\t", $deuze, etc.
    }

  3. #3
    Membre à l'essai
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    novembre 2014
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 32
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : novembre 2014
    Messages : 27
    Points : 20
    Points
    20

    Par défaut

    Citation Envoyé par Lolo78 Voir le message
    Il suffit de mettre les noms de champs à gauche de l'affectation du split, par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    foreach my $line (@fic) {	
        chomp($line);
        my ($prem, $deuze, $trois) = split /\t/, $line;
        # print OUT $prem, "\t", $deuze, etc.
    }


    Merci pour votre réponse.

    Dans ce cas je serai obligé de mettre toutes les colonnes (Sachant que j'ai des milliers de colonnes), alors que j'ai besoin que de 600.

    Je pense que je peux les récupérer à partir du "header" et puis "printer" seulement les colonnes dont j'ai besoin. Mais je ne sais pas comment le faire.

    Merci pour votre aide.

  4. #4
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    avril 2004
    Messages
    19 436
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : avril 2004
    Messages : 19 436
    Points : 496 991
    Points
    496 991

    Par défaut

    Bonjour,

    Si tu as 600 colonnes à afficher, il te faut de toute façon les identifier, tu comptais le faire comment, à partir du nom d'entête, à partir de la position de la colonne ?

  5. #5
    Membre à l'essai
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    novembre 2014
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 32
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : novembre 2014
    Messages : 27
    Points : 20
    Points
    20

    Par défaut

    Citation Envoyé par djibril Voir le message
    Bonjour,

    Si tu as 600 colonnes à afficher, il te faut de toute façon les identifier, tu comptais le faire comment, à partir du nom d'entête, à partir de la position de la colonne ?

    Oui, je voudrais identifier seulement les 600 à partir du nom d'entête, et ne pas par la position. Car mon fichier d'entrée risque de changer!(des colonnes de plus)

  6. #6
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    avril 2004
    Messages
    19 436
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : avril 2004
    Messages : 19 436
    Points : 496 991
    Points
    496 991

    Par défaut

    Je suppose que les entêtes seront sur la première ligne de ton fichier. Si oui, il te suffit de lire la première ligne de ton fichier, de comparer chaque valeur de la colonne avec tes noms à identifier et si ça correspond, tu sauvegardes la position de la colonne dans un tableau. À la fin de la lecture de la première ligne, tu auras ainsi dans un tableau toutes les positions de tes colonnes qui t'intéressent.
    Par la suite (ligne 2 à x), tu pourras extraire les colonnes voulues.

  7. #7
    Membre à l'essai
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    novembre 2014
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 32
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : novembre 2014
    Messages : 27
    Points : 20
    Points
    20

    Par défaut

    Citation Envoyé par djibril Voir le message
    Je suppose que les entêtes seront sur la première ligne de ton fichier. Si oui, il te suffit de lire la première ligne de ton fichier, de comparer chaque valeur de la colonne avec tes noms à identifier et si ça correspond, tu sauvegardes la position de la colonne dans un tableau. À la fin de la lecture de la première ligne, tu auras ainsi dans un tableau toutes les positions de tes colonnes qui t'intéressent.
    Par la suite (ligne 2 à x), tu pourras extraire les colonnes voulues.
    ça marche.
    Merci beaucoup

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

Discussions similaires

  1. Recherche des fichiers par leurs noms
    Par hackoofr dans le forum Vos Contributions VBScript
    Réponses: 0
    Dernier message: 26/05/2011, 13h08
  2. [XL-2002] Accéder à des boutons par leur nom
    Par miron dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 08/07/2009, 15h31
  3. Sélectionner des colonnes par leur numéro
    Par GnarlyYoyo dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 07/11/2007, 23h27
  4. détecter des colonnes par leur classe
    Par destructive dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 01/05/2007, 18h28
  5. Tuer des processus par leur nom
    Par tedparker dans le forum Access
    Réponses: 2
    Dernier message: 12/09/2006, 17h19

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