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 PHP Discussion :

La fonction extract retourne NULL pour une clé qui existe


Sujet :

Langage PHP

  1. #1
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 830
    Points
    5 830
    Billets dans le blog
    1
    Par défaut La fonction extract retourne NULL pour une clé qui existe
    Bonsoir,

    peut-être une de vos idées me mettra sur la piste...

    extract($line_csv); : je passe à la fonction extract le tableau associatif $line_csv. Une de ses clés est MANAGEREMAIL, donc la variable $MANAGEREMAIL devrait être créée. Pourtant un var_dump de cette variable donne NULL alors qu'un var_dump du tableau montre qu'il y a une valeur non nulle pour cette clé. Auriez-vous des idées ?

  2. #2
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 830
    Points
    5 830
    Billets dans le blog
    1
    Par défaut
    Bonjour,
    je pense avoir trouvé un bug de la fonction extract et j'aimerais avoir l'avis de spécialiste et une idée de contournement.

    Dans le post précédent, je signalais ma surprise d'appliquer cette fonction à un tableau associatif, fonction sensée retourner des variables dont le nom est la clé de chaque élément du tableau.

    Par exemple (pris dans la doc) :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <?php
    $var_array = array("color" => "blue",
    "size"  => "medium",
    "shape" => "sphere");
    extract($var_array);
     
    echo "color=".$color, "<br/>size=".$size, "<br/>shape=".$shape."<br/>";
    affiche
    color=blue
    size=medium
    shape=sphere
    et de constater qu'une variable qui devait être non nulle l'était quand même.

    En fait, l'erreur portait sur la première ligne d'un fichier CSV (le header). Donc la dernière colonne était ignorée (car c'est le dernier nom qui n'était pas vu). Un brin de debug m'a montré que la variable n'est pas créée (j'ai rajouté if (isset($MANAGEREMAIL)) var_dump($MANAGEREMAIL);else echo "MANAGEREMAIL does not exit<br/>";). J'ai donc modifié le fichier CSV en lui rajoutant une colonne et du coup la colonne ignorée est vue. Donc, comment contourner ce comportement ?

Discussions similaires

  1. Null sur une colonne qui existe pas
    Par punisher999 dans le forum NHibernate
    Réponses: 0
    Dernier message: 27/06/2012, 17h49
  2. Réponses: 2
    Dernier message: 27/12/2011, 09h38
  3. mapping hibernate pour une base qui existe déjà
    Par mennou dans le forum Hibernate
    Réponses: 2
    Dernier message: 23/05/2008, 03h03
  4. mapping hibernate pour une base qui existe déjà
    Par mennou dans le forum Hibernate
    Réponses: 1
    Dernier message: 18/05/2008, 11h16
  5. [VB.NET] Valur null pour une date.
    Par Lois dans le forum Windows Forms
    Réponses: 2
    Dernier message: 20/12/2004, 14h38

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