[php] lecture d'un tableau
Résolu
antic80
Messages postés
4785
Date d'inscription
Statut
Contributeur
Dernière intervention
-
olm -
olm -
Bonsoir
voila j'ai beaucoup de mal a comprendre a les tableaux en php
j'ai un code dans ce genre
je sais pas si ce code est bon
en fait ce que je veux faire un peu plus bas c'est
récupérer le numéro de la question en cours (ca je sais faire)
afficher la question correspondant au numéro (la ca merde car le code me renvoie la question n°2 a chaque fois)
voila j'ai beaucoup de mal a comprendre a les tableaux en php
j'ai un code dans ce genre
$NbQ=mysql_num_rows($req); //je compte le nombre de ligne de ma requete while($row = mysql_fetch_array($req)) { for($i=1; $i<$NbQ+1;$i++){ $Id[$i]=$row['id']; $Cat[$i]=$row['Categorie']; $Question[$i]=$row['question']; } }
je sais pas si ce code est bon
en fait ce que je veux faire un peu plus bas c'est
récupérer le numéro de la question en cours (ca je sais faire)
afficher la question correspondant au numéro (la ca merde car le code me renvoie la question n°2 a chaque fois)
A voir également:
- [php] lecture d'un tableau
- Tableau word - Guide
- Trier un tableau excel - Guide
- Tableau ascii - Guide
- Imprimer un tableau excel - Guide
- Tableau croisé dynamique - Guide
5 réponses
Salut,
Chaque appel à mysql_fetch_array() retourne une ligne résultat de ta requette.
Donc la boucle for dans le while ne sert pas à grand chose.
Ajoute donc une gestion de ton indice dans le while et supprime le for. Tu
peux ainsi remplacer ton while par un for (plus élégant) :
A+, crabs
Chaque appel à mysql_fetch_array() retourne une ligne résultat de ta requette.
Donc la boucle for dans le while ne sert pas à grand chose.
Ajoute donc une gestion de ton indice dans le while et supprime le for. Tu
peux ainsi remplacer ton while par un for (plus élégant) :
for($i=1;$row = mysql_fetch_array($req); $i++) { $Id[$i]=$row['id']; $Cat[$i]=$row['Categorie']; $Question[$i]=$row['question']; }
A+, crabs
olm
enfin ce que je cherchais en vain...depuis 2 jours !!!
alors voila que ce soit avec ton code ou le mien j'ai un soucis
le but de la page est d'afficher une question en fonction de son numéro.
si j'affiche les valeurs du tableau tout va bien
a partir de cette page je valide la reponse et fais appelle a une page de verification qui en plus de verifier la réponse , incremente le numéro de la question.
au retour sur la feuille principale le numéro de la question est bon mais j'obtient pour la question le message d'erreur suivant
undefined variable $Tab......
en fait il ne reconnait plus le tableau
voila le code de la page principale
et voici le code de la page verif
je m'en sort pas du tout
le but de la page est d'afficher une question en fonction de son numéro.
si j'affiche les valeurs du tableau tout va bien
a partir de cette page je valide la reponse et fais appelle a une page de verification qui en plus de verifier la réponse , incremente le numéro de la question.
au retour sur la feuille principale le numéro de la question est bon mais j'obtient pour la question le message d'erreur suivant
undefined variable $Tab......
en fait il ne reconnait plus le tableau
voila le code de la page principale
$Server="localhost"; $User="root"; $Password=""; $db = mysql_connect($Server, $User, $Password) or die('Erreur de connexion '.mysql_error()); mysql_select_db('mysql',$db) or die('Erreur de selection '.mysql_error()); if(isset($_GET['categorie'])) $Categorie=$_GET['categorie']; else $Categorie=""; $sql = "SELECT * FROM questions where Categorie='$Categorie'"; // on envoie la requête $req = mysql_query($sql) or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error()); $NbQ=mysql_num_rows($req); $sql2 = "SELECT * FROM apprenant where nom='$Nom' and prenom='$Prenom' and pseudo='$pseudom'"; $req2 = mysql_query($sql2) or die('Erreur SQL !<br>'.$sql2.'<br>'.mysql_error()); while($row = mysql_fetch_array($req2)) { $NumQuestion=$row['NumQuestion']; } $i=1; $NbQ=$NbQ+1; while($row= mysql_fetch_array($req)) { $Id=$row['id']; $Cat=$row['Categorie']; $Question=$row['question']; $Num=$i++; $Tab[$Num]=array($Id,$Cat,$Question); } ?>
et voici le code de la page verif
<?php $Nom=$_SESSION['nom']; $Prenom=$_SESSION['prenom']; @$pseudom=addslashes(htmlentities($_SESSION['pseudom'])); $sql = "SELECT * FROM apprenant where nom='$Nom' and prenom='$Prenom' and pseudo='$pseudom'"; $req = mysql_query($sql) or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error()); while($row = mysql_fetch_array($req)) { $NumQuestion=$row['NumQuestion']; } $NumQuestion=$NumQuestion+1; $sql2="UPDATE apprenant SET NumQuestion='$NumQuestion' where nom='$Nom' and prenom='$Prenom' and pseudo='$pseudom'"; $req2 = mysql_query($sql2) or die('Erreur SQL !<br>'.$sql2.'<br>'.mysql_error()); ?>
je m'en sort pas du tout
Salut,
Les morceaux de code que tu donnes ne montre pas l'erreur.
Donnes le message d'erreur en entier ainsi que les lignes qui peuvent
être intéressantes pour en trouver la raison et en particulier celle qui
provoque l'erreur.
Donne aussi les structure de tes tables. Le numéro de la question devrait
être dans ta table questions et il serait préférable que tu fasses des requettes
avec des clause restrictive de type "WHERE NumQuestion='...' plutôt que
de parcourir la table à chaque fois.
A+, crabs
Les morceaux de code que tu donnes ne montre pas l'erreur.
Donnes le message d'erreur en entier ainsi que les lignes qui peuvent
être intéressantes pour en trouver la raison et en particulier celle qui
provoque l'erreur.
Donne aussi les structure de tes tables. Le numéro de la question devrait
être dans ta table questions et il serait préférable que tu fasses des requettes
avec des clause restrictive de type "WHERE NumQuestion='...' plutôt que
de parcourir la table à chaque fois.
A+, crabs
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question