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 :

Problème de récupération de tableau dans hash DBM


Sujet :

Langage Perl

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 73
    Points : 49
    Points
    49
    Par défaut Problème de récupération de tableau dans hash DBM
    J'ai un petit soucie avec un DBM, je n'arrive pas a récupérer mes données.

    Voila mon script de teste :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    #!/usr/bin/perl -w
    use strict;
    use AnyDBM_File;
    use DB_File;
    use diagnostics;
    my @i = qw/ a b c d /;
     my $new_filename = "test.dat";
     my %newhash = ();
    tie %newhash,  'DB_File', $new_filename, O_CREAT|O_RDWR;
    $newhash{'teste'} = [@i];
    pour récupérer mes données je fait comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
      tie(my %HIST, 'DB_File', 'test', 1, 0);
      my $i = $HIST{'teste'};
      print @$i[0];
      untie(%HIST)
    le problème ce trouve la
    my $i = $HIST{'teste'};
    print @$i[0];
    je ne comprend pas ou est mon erreur d'autant quand faisant un teste avec un autre script que voila :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    #!/usr/bin/perl -w
    use strict;
    my @i = qw/ a b c d /;
     
    my %l;
     
    $l{'reteste'} = [@i];
     
    my $m = $l{'reteste'};
     
    print @$m[2];
    Tout vas bien

    Perl me renvoie l'erreur suivante :


    Can't use string ("ARRAY(0x1a01354)") as an ARRAY ref while "strict refs" in
    use at C:\DOCUME~1\Siaoly\Bureau\cache.pl line 22 (#1)
    (F) Only hard references are allowed by "strict refs". Symbolic
    references are disallowed. See perlref.

    Uncaught exception from user code:
    Can't use string ("ARRAY(0x1a01354)") as an ARRAY ref while "strict refs" in use at C:\DOCUME~1\Siaoly\Bureau\cache.pl line 22.
    at C:\DOCUME~1\Siaoly\Bureau\cache.pl line 22

  2. #2
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    Par défaut, les modules DBM ne peuvent stocker que des hashs à un niveau, ils ne préservent pas les structures de données complexe comme la tienne (hash de tableau). Pour outrepasser cette limitation, tu peux essayer MLDBM .

    --
    Jedaï

Discussions similaires

  1. Problème de Récupération de Context dans un tableau
    Par wajdi.bengagi dans le forum JSF
    Réponses: 0
    Dernier message: 29/10/2009, 12h11
  2. [WebForms]Problème de récupération de valeur dans GridView
    Par Dadou74 dans le forum Général Dotnet
    Réponses: 6
    Dernier message: 05/12/2006, 15h47
  3. [MySQL] Problème de récupération des données dans une fonction
    Par highman dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 26/10/2006, 20h04
  4. Problème de récupérations de données dans une table mysql
    Par Helpine dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 09/03/2006, 19h07

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