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

Langage Perl Discussion :

Suppression d'un array d'array


Sujet :

Langage Perl

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    195
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2013
    Messages : 195
    Points : 121
    Points
    121
    Par défaut Suppression d'un array d'array
    Bonjour,

    Je dois utiliser un fichier excel pour plus tard me connecter à divers équipements de constructeurs différents en récupérant les valeurs des lignes dans des variables.

    Mais je bloque sur une chose bête, je pense, c'est que je ne veux pas de la première ligne ...et je ne sais pas comment la supprimer (voir l'a zapper au moment de la création de l'array).

    Mon Code

    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
    18
    19
    20
    use warnings;
    use strict;
    use v5.22;
    use Data::Dumper;
    use Spreadsheet::Read;
     
     
    my $book  = ReadData ("excel.xls");
    my @rows = Spreadsheet::Read::rows($book->[1]);
     
    print Dumper @rows;
     
    delete @rows[0];
    #undef @rows[0];
     
    print Dumper @rows;
     
    foreach my $ligne (@rows) {
    		say "@${ligne}";
    	}
    Résultat

    $VAR1 = [
    'IP',
    'NOM',
    'CONSTRUCTEUR',
    'VILLE'
    ];
    $VAR2 = [
    '10.0.0.1',
    'TOTO-1',
    'CISCO',
    'DIEPPE'
    ];
    $VAR3 = [
    '10.0.0.2',
    'TOTO-2',
    'HP',
    'DIEPPE'
    ];
    $VAR4 = [
    '10.0.0.3',
    'TOTO-3',
    'XTREM',
    'DIEPPE'
    ];
    $VAR1 = undef;
    $VAR2 = [
    '10.0.0.1',
    'TOTO-1',
    'CISCO',
    'DIEPPE'
    ];
    $VAR3 = [
    '10.0.0.2',
    'TOTO-2',
    'HP',
    'DIEPPE'
    ];
    $VAR4 = [
    '10.0.0.3',
    'TOTO-3',
    'XTREM',
    'DIEPPE'
    ];
    Can't use an undefined value as an ARRAY reference at test.pl line 22.

    Il faudrait supprimer $VAR1 pour tout décaler à gauche mais je ne trouve pas la solution

    Quelqu'un aurait une piste?

    Merci

  2. #2
    Membre régulier
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    195
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2013
    Messages : 195
    Points : 121
    Points
    121
    Par défaut
    Avec une copie d'écran ca ira mieux

    Nom : excel.png
Affichages : 90
Taille : 4,5 Ko

  3. #3
    Membre régulier
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    195
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2013
    Messages : 195
    Points : 121
    Points
    121
    Par défaut
    Bon bah en fait j'ai trouvé à taton et par hasard avec la commande splice (source :http://perlmaven.com/undef-on-perl-arrays-and-hashes )

    La commande splice suprrime le undef même si $VAR1 existe toujours.
    Ca ne fait pas très propre mais ca fonctionne.

    La question pour supprimer $Var1 est toujours d'acualité

    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
    18
    19
    20
    use warnings;
    use strict;
    use v5.22;
    use Data::Dumper;
    use Spreadsheet::Read;
     
     
    my $book  = ReadData ("excel.xls");
    my @rows = Spreadsheet::Read::rows($book->[1]);
     
    print Dumper @rows;
     
    splice(@rows[0]); 
     
     
    print Dumper @rows;
     
    foreach my $ligne (@rows) {
    		say "@${ligne}";
    	}
    Résultat

    10.0.0.1 TOTO-1 CISCO DIEPPE
    10.0.0.2 TOTO-2 HP DIEPPE
    10.0.0.3 TOTO-3 XTREM DIEPPE

  4. #4
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    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 612
    Points : 12 256
    Points
    12 256
    Billets dans le blog
    1
    Par défaut
    Essaie ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    use strict;
    use warnings;
     
    use Data::Dumper;
    my @rows = ( ["row1", 1], ["row2", 2], ["row3", 3] );
    print Dumper \@rows;
    my $useless = shift @rows;
    print Dumper \@rows;
    Affichage:
    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
     
    $VAR1 = [
              [
                'row1',
                1
              ],
              [
                'row2',
                2
              ],
              [
                'row3',
                3
              ]
            ];
     
    $VAR1 = [
              [
                'row2',
                2
              ],
              [
                'row3',
                3
              ]
            ];
    Autre solution:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    @rows = @rows[1..$#rows];

  5. #5
    Membre régulier
    Homme Profil pro
    Inscrit en
    Mai 2013
    Messages
    195
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2013
    Messages : 195
    Points : 121
    Points
    121
    Par défaut
    Merci Lolo

    Effectivement ca change tout
    Et c'était tout bête

    AU début j'avais pensé à shift mais comme ceci
    Ce qui navait juste retiré une valeur dans la première array.

    Au final
    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
    18
    19
    20
    21
     
     
    use warnings;
    use strict;
    use v5.22;
    use Data::Dumper;
    use Spreadsheet::Read;
     
     
    my $book  = ReadData ("excel.xls");
    my @rows = Spreadsheet::Read::rows($book->[1]);
     
    print Dumper \@rows;
     
    shift @rows; 
     
    print Dumper \@rows;
     
    foreach my $ligne (@rows) {
    		say "@${ligne}";
    	}
    Résultat

    $VAR1 = [
    [
    'IP',
    'NOM',
    'CONSTRUCTEUR',
    'VILLE'
    ],
    [
    '10.0.0.1',
    'TOTO-1',
    'CISCO',
    'DIEPPE'
    ],
    [
    '10.0.0.2',
    'TOTO-2',
    'HP',
    'DIEPPE'
    ],
    [
    '10.0.0.3',
    'TOTO-3',
    'XTREM',
    'DIEPPE'
    ]
    ];
    $VAR1 = [
    [
    '10.0.0.1',
    'TOTO-1',
    'CISCO',
    'DIEPPE'
    ],
    [
    '10.0.0.2',
    'TOTO-2',
    'HP',
    'DIEPPE'
    ],
    [
    '10.0.0.3',
    'TOTO-3',
    'XTREM',
    'DIEPPE'
    ]
    ];
    10.0.0.1 TOTO-1 CISCO DIEPPE
    10.0.0.2 TOTO-2 HP DIEPPE
    10.0.0.3 TOTO-3 XTREM DIEPPE

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

Discussions similaires

  1. cell array --> double array ?
    Par Truth dans le forum MATLAB
    Réponses: 2
    Dernier message: 06/04/2008, 14h24
  2. Array of array en dynamique
    Par Archimède dans le forum Langage
    Réponses: 16
    Dernier message: 03/11/2007, 17h01
  3. [Tableaux] array => fichier => array ?
    Par adimou dans le forum Langage
    Réponses: 2
    Dernier message: 26/08/2007, 21h22
  4. Déclaration de type array of array of variant
    Par Drooxy dans le forum Delphi
    Réponses: 4
    Dernier message: 14/12/2006, 19h25
  5. Comment faire le tri d'un array of array ?
    Par Tchouffy dans le forum Langage
    Réponses: 1
    Dernier message: 16/06/2005, 20h55

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