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

PHP & Base de données Discussion :

affichage en 2 colonnes [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de legrandse
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    Décembre 2010
    Messages
    354
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de service informatique

    Informations forums :
    Inscription : Décembre 2010
    Messages : 354
    Par défaut affichage en 2 colonnes
    Re bonjour à tous,

    J'avoue, je n'ai aucun mérite car j'ai recopié ce code qui fonctionne bien mais qui n'est pas tout à fait ce que je souhaitais.

    Dans ma table j'ai par exemple 17 enregistrements (qui peuvent varier entre 16 et 20)

    Je souhaitais afficher dans la colonne de gauche les 10 premiers enregistrement et dans celle de droite le reste.

    Le script que j'ai recopié, affiche le 1er dans la colonne de gauche, le 2ème dans celle de droite, le 3ème à gauche, ....

    Qqun peut-il m'aider svp ?


    Merci merci.


    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    $sql = "SELECT * FROM agenda ORDER by date_debut ASC "; 
     
    // on envoie la requête
    $req = mysql_query($sql) or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error());
     
     
     
    while ($data = mysql_fetch_assoc($req)) 
       {
      $tablo[]=$data;
      }
      //détermine le nombre de colonnes
      $nbcol=2;
     
      echo '<table>';
      $nb=count($tablo);
      for($i=0;$i<$nb;$i++){
     
      //les valeurs à afficher
      $valeur1=$tablo[$i]['lieu'];
      $valeur2=$tablo[$i]['date_debut'];
     
      if($i%$nbcol==0)
      echo '<tr>';
      echo '<td>',$valeur1,'</td>';
      echo '<td>',$valeur2,'</td>';
     
      if($i%$nbcol==($nbcol-1))
      echo '</tr>';
     
      }
      echo '</table>';

  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
    Par défaut
    A moins que tu tiennes reellement a un tableau HTML, tu peux avoir deux contenu côte à côte en CSS :
    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
    $sql = "SELECT lieu, date_debut FROM agenda ORDER by date_debut ASC "; 
    $req = mysql_query($sql);
     
    $i = 0;
    $c = 0;
    while ($data = mysql_fetch_assoc($req)) {
       ++$i;
       if ($i == 10) {
             $c++;
       }
       $div[$c].= $data['date_debut'] . ' ' . htmlspecialchars($data['lieu']).'<br/>';
    }
     
    foreach ($div as $content) {
         echo '<div style="float :left;">' . $content . '</div>';
    }
    Apres pour un tableau HTML on peur ruser :
    [CODE]
    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
    19
    20
    21
    22
    23
    24
    $sql = "SELECT lieu, date_debut FROM agenda ORDER by date_debut ASC "; 
    $req = mysql_query($sql);
     
    $i = 0;
    $c = 0;
    while ($row= mysql_fetch_assoc($req)) {
       $data[] = $row;
    }
     
    echo '<table>';
    for ($i = 0; $i <= 10; $i++) {
        if (!isset($data[$i])) { break; }
        else {
           echo '<tr><td>' . $data[$i]['date_debut'] . </td><td> . htmlspecialchars($data[$i]['lieu']) . '</td>';
           $j = $i + 10;
           if (isset($data[$j]) {
             echo '<tr><td>' . $data[$j]['date_debut'] . </td><td> . htmlspecialchars($data[$j]['lieu']) . '</td>';
           }
           else {
             echo '<tr><td></td><td></td></tr>';
          }
       }
    }
    echo '</table>';
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre éclairé Avatar de legrandse
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    Décembre 2010
    Messages
    354
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de service informatique

    Informations forums :
    Inscription : Décembre 2010
    Messages : 354
    Par défaut
    Je te remercie beaucoup pour tes deux solutions.

    Je viens d'essayer la deuxième car j'ai besoin d'un tableau en HTML mais cela ne fonctionne pas pour le moment.

    Il m'affiche les enregistrements dans une seule colonne au lieu de 2.

  4. #4
    Membre Expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 59
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Billets dans le blog
    8
    Par défaut
    Tu veux donc un tableau dans ce goût ?

    Nom : tab.jpg
Affichages : 537
Taille : 23,8 Ko

    et qui donnerait donc le HTML suivant

    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <table border="1">
    	<tr>
    	   <tr><th colspan="2">Les 10 premiers</th><th colspan="2">Les 10 derniers</th></tr>
    	   <tr><td>Premier lieu</td><td>Premiere date</td><td>Onzieme lieu</td><td>Onzieme date</td></tr>
    		<tr><td>Second lieu</td><td>Seconde date</td><td>Douzieme lieu</td><td>Douzieme date</td></tr>
    	</tr>
    </table>
    tu comprends pourquoi c'est beaucoup plus logique d'utiliser des div qu'un tableau HTML ?
    tu veux de la cosmétique là, pas de la logique de tableau HTML.
    Le tableau HTML correspond à
    une ligne = un donnée, une colonne = un champ de la donnée

    alors bon, on peut toujours prendre une ferrari pour faire taxi en ville... mais bon, on peut faire simple aussi.
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  5. #5
    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
    Par défaut
    J'avais mis un <tr> en trop :

    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
    echo '<table>';
    for ($i = 0; $i <= 10; $i++) {
        if (!isset($data[$i])) { break; }
        else {
           echo '<tr><td>' . $data[$i]['date_debut'] . '</td><td>' . htmlspecialchars($data[$i]['lieu']) . '</td>';
           $j = $i + 10;
           if (isset($data[$j])) {
             echo '<td>' . $data[$j]['date_debut'] . '</td><td>' . htmlspecialchars($data[$j]['lieu']) . '</td>';
           }
           else {
             echo '<td></td><td></td></tr>';
          }
       }
    }
    echo '</table>';
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  6. #6
    Membre éclairé Avatar de legrandse
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    Décembre 2010
    Messages
    354
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de service informatique

    Informations forums :
    Inscription : Décembre 2010
    Messages : 354
    Par défaut
    Cà fonctionne parfaitement maintenant. Merci à toi Sabotage

    Et Dendrite merci du conseil pour les Div (suis toujours impressionné quand une fille est développeur web )

  7. #7
    Membre éclairé Avatar de legrandse
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    Décembre 2010
    Messages
    354
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de service informatique

    Informations forums :
    Inscription : Décembre 2010
    Messages : 354
    Par défaut
    Euuuh je ne sais pas si je peux rouvrir le sujet mais je voulais voir pour ma culture perso comment faire avec l'exemple des Div. Il affiche bien les résultats en 2 colonnes mais j'ai des erreurs de type:

    Notice: Undefined variable: div
    Notice: Undefined offset: 0
    Notice: Undefined offset: 1
    Comment régler ces erreurs svp ?

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

Discussions similaires

  1. Affichage ComboBox multi-colonnes
    Par dough29 dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 04/12/2005, 12h28
  2. zone de liste : affichage de deux colonnes
    Par niclalex dans le forum IHM
    Réponses: 3
    Dernier message: 27/10/2004, 22h51
  3. [XSLT] Affichage dans 2 colonnes ou plus ?
    Par stebar dans le forum XSL/XSLT/XPATH
    Réponses: 6
    Dernier message: 05/08/2004, 09h07
  4. DBGrid: formatage de l'affichage d'une colonne
    Par SAca dans le forum Bases de données
    Réponses: 6
    Dernier message: 14/05/2004, 17h33
  5. DBGrid - Affichage sur 2 colonnes
    Par Grouik dans le forum Bases de données
    Réponses: 2
    Dernier message: 20/04/2004, 17h37

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