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 :

[Tableaux] Concaténation du nom d'une variable


Sujet :

Langage PHP

  1. #1
    Membre expérimenté Avatar de nebule
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    1 507
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 507
    Points : 1 464
    Points
    1 464
    Par défaut [Tableaux] Concaténation du nom d'une variable
    Bonjour,

    Je suis toujours la génération de mon fichier Excel et j'ai besoin de pouvoir générer plusieurs feuilles suivant le nombre de résultat à afficher (donc très varaible).

    J'ai essayé dans ma petite boucle for de faire un tableau de ce type $sheet[$var] mais ca ne lui plait pas le tableau.

    Si je nomme les pages en dur $sheet1, $sheet2, $sheet3 ca marche mais comment faire pour nommer les pages de cette façon en générique ?

    J'ai testé $sheet.$var= ... mais sans succés!


    Merci
    (\ _ /)
    (='.'=)
    (")-(")

  2. #2
    Expert éminent
    Avatar de titoumimi
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    3 707
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 707
    Points : 7 285
    Points
    7 285
    Par défaut
    un très bon sujet qui aborde les différentes solutions :

    http://developpez.net/forums/showthread.php?t=142695

    Globalement inoffensif
    Merci de respecter les règles du forum.
    Aucune question technique par MP !
    _______________________________________________________________________
    Cours Ruby et Ruby on Rails (RoR) - Cours PHP - FAQ Ruby / Rails - Livres Ruby / Rails
    Ajax facile avec Ruby on Rails, Prototype, script.aculo.us et les RJS
    Tutoriaux HTML/CSS et PHP

  3. #3
    Membre expérimenté

    Homme Profil pro
    Inscrit en
    Janvier 2004
    Messages
    1 249
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 249
    Points : 1 565
    Points
    1 565

  4. #4
    Expert éminent
    Avatar de Swoög
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    6 045
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 6 045
    Points : 8 339
    Points
    8 339
    Par défaut
    Citation Envoyé par nebule
    J'ai essayé dans ma petite boucle for de faire un tableau de ce type $sheet[$var] mais ca ne lui plait pas le tableau.
    Comment ça ça lui plait pas ? j'ai jamais vu PHP ne pas aimer un tableau, c'est le meilleur langage pour les tableaux, on peut faire tout ce qu'on veut (ou presque )

    Citation Envoyé par nebule
    Si je nomme les pages en dur $sheet1, $sheet2, $sheet3 ca marche mais comment faire pour nommer les pages de cette façon en générique ?

    J'ai testé $sheet.$var= ... mais sans succés!


    Merci
    pour avoir un nom de variable générique, tu as deux choix :
    soit tu mets le nom de ta variable dans une autre variable et tu y accèdes avec $$ exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $bouh = 0;
    $name = 'bouh';
    $$name = 'A';
    echo $bouh; //affiche A
    ça va pas être très pratique dans ton cas...
    deuxième solution, utilser ${} :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ${$sheet.$var} = 'COUCOU';
    Rédacteur "éclectique" (XML, Cours PHP, Cours JavaScript, IRC, Web...)
    Les Règles du Forum - Mon Site Web sur DVP.com (Développement Web, PHP, (X)HTML/CSS, SQL, XML, IRC)
    je ne répondrai à aucune question technique via MP, MSN ou Skype : les Forums sont là pour ça !!! Merci de me demander avant de m'ajouter à vos contacts sinon je bloque !
    pensez à la balise [ code ] (bouton #) et au tag (en bas)

  5. #5
    Membre expérimenté Avatar de nebule
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    1 507
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 507
    Points : 1 464
    Points
    1 464
    Par défaut
    Citation Envoyé par titoumimi
    un très bon sujet qui aborde les différentes solutions :

    http://developpez.net/forums/showthread.php?t=142695

    pas mal, j'avais pas trouvé ce topic (pas cherché avec ces mots clefs là)

    Donc j'ai fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <?php
    for($var=1;$var>$nbPages;$var++)
    {
     $sheet = "sheet".$var;
    
      $$sheet=$book->Worksheets($var);//$sheet contient la feuille active
      $$sheet=->Name="Résultats des tests ".$var;//Attribution d'un nom à la feuille
     
      $cellB2=$$sheet->Range("B2");
      $cellB2->value="Nom du produit : ";
    }
    ?>
    Ou encore

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <?php
    for($var=1;$var>$nbPages;$var++)
    {
      ${"sheet".$var}=$book->Worksheets($var);//$sheet contient la feuille active
      ${"sheet".$var}=->Name="Résultats des tests ".$var;//Attribution d'un nom à la feuille
      
      $cellB2=${"sheet".$var}->Range("B2");
      $cellB2->value="Nom du produit : ";
    }
    ?>
    Mais sans succés, j'ai une belle erreur :
    Parse error: syntax error, unexpected T_OBJECT_OPERATOR in C:\wamp\www\Browser\pageExcel.php on line 41

    Heu ca veut dire quoi ca ?

    Merci
    (\ _ /)
    (='.'=)
    (")-(")

  6. #6
    Membre expérimenté

    Homme Profil pro
    Inscrit en
    Janvier 2004
    Messages
    1 249
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 249
    Points : 1 565
    Points
    1 565
    Par défaut
    =->
    Je voudrais que tu me trouve la page de doc qui parle de cette syntaxe ;o)

  7. #7
    Membre confirmé
    Profil pro
    Développeur Web
    Inscrit en
    Avril 2006
    Messages
    430
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2006
    Messages : 430
    Points : 557
    Points
    557
    Par défaut
    Hellow,

    le unexpected T_OBJECT_OPERATOR (qui est en fait: ->), je dirais que c'est à cause de ca:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ${"sheet".$var}=->Name
    Merci à Microsoft pour avoir transformé un métier relativement terne et basé sur une approche bêtement technique et rigoureuse des faits, en challenge quotidien, nécessitant une remise en question permanente à l'échelle du quart d'heure

  8. #8
    Membre expérimenté Avatar de nebule
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    1 507
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 507
    Points : 1 464
    Points
    1 464
    Par défaut
    Citation Envoyé par Fladnag
    Je voudrais que tu me trouve la page de doc qui parle de cette syntaxe ;o)
    hum mauvais copié collé de ma part

    Alors j'ai testé ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php
    
    ${"sheet".$var}=$book->Worksheets($var);//$sheet contient la feuille active
      ${"sheet".$var}->Name="Résultats des tests ".$var;//Attribution d'un nom à la feuille
     
      $cellB2=${"sheet".$var}->Range("B2");
      $cellB2->value="Nom du produit : ";
    ?>
    Ca me fait plus d'erreur mais il s'en moque royalement ...
    Il ne prend pas en compte la chose et ne fonctionne pas (ne nomme pas mes différentes pages, n'inscrit pas dans la cellule...

    idem avec $$sheet

    D'autres idées ?
    (\ _ /)
    (='.'=)
    (")-(")

  9. #9
    Membre expérimenté Avatar de nebule
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    1 507
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 507
    Points : 1 464
    Points
    1 464
    Par défaut
    Citation Envoyé par Swoög
    Comment ça ça lui plait pas ? j'ai jamais vu PHP ne pas aimer un tableau, c'est le meilleur langage pour les tableaux, on peut faire tout ce qu'on veut (ou presque )
    bah j'ai re-essayé ! et ca me fait la meme chose qu'avec $$sheet ou ${"sheet".$var} ... c'est à dire rien!

    Ca me crée mes 3 feuilles (j'en ai 3 vu le nombre de résultats) mais rien à faire, il ne veut rien mettre dedans ni me les nommer correctement
    (\ _ /)
    (='.'=)
    (")-(")

  10. #10
    Membre expérimenté Avatar de nebule
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    1 507
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 507
    Points : 1 464
    Points
    1 464
    Par défaut
    Alors alors quelques petits détails de plus ...

    Quand je n'ai qu'une feuille à générer ... ca ne marche pas non plus mais si je ne mets pas ma boucle for ... ca marche!!! même avec les $$ !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <?php
    $var=1;
    /*for($var=1;$var>$nbPages;$var++)
    {*/
      $sheet = "sheet".$var;
      $$sheet=$book->Worksheets($var);//$sheet contient la feuille active
      $$sheet->Name="Résultats des tests ".$var;//Attribution d'un nom à la feuille
      
      $cellB2=$$sheet->Range("B2");
      $cellB2->value="Nom du produit : ";
    //}
    ?>
    Colorez votre code PHP sur les forums grâce à Developpez.com

    En quoi la boucle for géne telle ?
    (\ _ /)
    (='.'=)
    (")-(")

  11. #11
    Membre expérimenté Avatar de nebule
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    1 507
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 507
    Points : 1 464
    Points
    1 464
    Par défaut
    haaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa saleté de truc!

    Ca marche avec une boucle while...
    Me demandez pas comment mais ca marche
    Bon bah encore un post pseudo-résolu

    Merci,
    Marie
    (\ _ /)
    (='.'=)
    (")-(")

  12. #12
    Membre expérimenté

    Homme Profil pro
    Inscrit en
    Janvier 2004
    Messages
    1 249
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 249
    Points : 1 565
    Points
    1 565
    Par défaut
    p'tet parce que la condition de ton for était :

    alors qu'elle aurait du etre :
    ;o)

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

Discussions similaires

  1. [Tableaux] Récupérer le nom d'une variable
    Par Tchupacabra dans le forum Langage
    Réponses: 4
    Dernier message: 20/05/2008, 17h55
  2. Concaténer le nom d'une variable
    Par PKing dans le forum ActionScript 3
    Réponses: 2
    Dernier message: 06/05/2008, 23h42
  3. Réponses: 6
    Dernier message: 13/06/2007, 09h05
  4. [Tableaux] changer le nom d'une variable
    Par drakenzara dans le forum Langage
    Réponses: 5
    Dernier message: 11/02/2007, 11h12
  5. [Tableaux] Récupérer le nom d'une variable
    Par lem dans le forum Langage
    Réponses: 6
    Dernier message: 06/02/2007, 10h21

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