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 :

Acceder aux données d'un tableau de chaines en 2 dimensions. [PHP 5.6]


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    155
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 155
    Points : 94
    Points
    94
    Par défaut Acceder aux données d'un tableau de chaines en 2 dimensions.
    Bonjour Cela fait longtemps que je n'ai pas programmé en PHP, j'ai l'impression d'avoir tout oublié.
    Je n'arrive même plus à accéder aux données d'un tableau... ni à créer un tableau de classes...
    Bref,
    J'ai créé une fonction qui crée un Deck de cartes tableaux:
    que je résume
    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
     
    $this->arrayCardObjectif	=array('INV','PRI','SAT','SUB','CAS');
    $this->arrayCardSpecial		=array('SUPPLY','INFILTRATION','SUPPORT','MEDIA');
     
    function CreateCards(){
     
    	// Add Sentinels
    	$id=1;
            for ($i=0; $i<6; $i++)	$this->cards[] = array ('id'=> $id++,'type' => 'SEN', 'level' =>2,'potentiel'=>15,"location"=>'TDO');
     
    	//Add objectifs
    	foreach( $this->arrayCardObjectif as $power_id )
    		$this->cards[] = array ('id'=> $id++,'type' => 'OBJ', 'level' => 6,'power' => $power_id,'potentiel'=>'20',"location"=>'TDO');
     
             //Add Special cards
    	foreach( $this->arrayCardSpecial as $power_id )
    		$this->cards[] = array ('id'=> $id++,'type' => 'SPE','power' => $power_id,"location"=>'TDO')
    }
    j'essaye d'y acceder ainsi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
            $this->CreateCards();
    	foreach($this->cards as $count=>$zearray ){
    		$values3[]="(`"	.$zearray['type']."`,`"
    				.$zearray['color']."`,`"
    				.$zearray['power']."`,`"
    				.$zearray['level']."`,`"
    				.$zearray['potentiel']."`,`" 
    				.$zearray['status']."`,`"
    				.$zearray['location']."`)";
    	}
    1ere question:
    Ce n'est pas ainsi que l'on y accède? Tous ne possèdent pas les mêmes caractéristiques utilisées (par exemple dans le level n'est pas utilisé pour les special cards)

    2eme question:
    Si je ne peux pas mettre par défaut, je voulais passer par la creation d'une classe card à la place de la deuxième dimension, mais je n'ai pas trouvé d'exemple pour définir un tableau de classe
    class Card
    { .....
    }

    Comment déclare t'on un tableau de cette class (style en C: $this->Card = array of Card )

    merci d'avance.




    merci d'avance pour votre aide.

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Qu'essaies-tu de faire dans le deuxième code ?
    A quoi correspondent $zearray et $values3 ?

    Revois quand même déjà l'utilisation de foreach
    http://php.net/manual/fr/control-structures.foreach.php
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    155
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 155
    Points : 94
    Points
    94
    Par défaut
    j'initialise une portion de chaine pour un insert SQL. (implode avec "," puis un DBQuery ).

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Pour l'insertion il faudra bien une valeur pour chaque colonne.
    Donc autant tout renseigner quel que soit le type de carte dans ton tableau PHP, même si c'est NULL. Ca evitera d'écrire du code inutile ensuite dans le traitement.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    155
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 155
    Points : 94
    Points
    94
    Par défaut
    Non pas necessairement vu que j'ai mis des valeurs par Defaut dans la création de la table...
    Mais la question n'était pas là

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Si justement puisque ton problème est qu'en PHP tu n'as pas les mêmes attributs selon le type de carte alors qu'en Mysql elles finissent dans la même table.
    Si tu ne veux pas renseigner une valeur par défaut du côté PHP, il te faudra nécessairement une requête différente par type de carte, soit manuellement, soit en construisant dynamiquement les colonnes de la requête INSERT à partir des index existant dans le tableau fourni.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

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

Discussions similaires

  1. GLSL Probleme acceder aux valeurs d'un tableau
    Par tib0000 dans le forum OpenGL
    Réponses: 1
    Dernier message: 29/01/2008, 14h21
  2. [WEB]Acceder aux données via internet
    Par nboubeur dans le forum ASP
    Réponses: 59
    Dernier message: 23/05/2007, 00h26
  3. [WEB]Acceder aux données via internet
    Par nboubeur dans le forum Access
    Réponses: 8
    Dernier message: 23/04/2007, 12h54
  4. Réponses: 2
    Dernier message: 07/02/2007, 14h40
  5. Acceder aux données d'un fichier .datas
    Par euromed.hl dans le forum 4D
    Réponses: 4
    Dernier message: 14/06/2006, 23h56

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