Twitter iPhone pliant OnePlus 11 PS5 Disney+ Orange Livebox Windows 11

Tableau a decouper

24 réponses
Avatar
Pascale
Bonjour,

Je bute le problème suivant :

Je génère un zouli tableau comme suit :

$ordre=$_GET['ordre'];
// L'utilisateur a le choix de l'ordre d'affichage des fiches
if ($ordre=='')
{$sel="SELECT numfiche,nom,datevalid from matable WHERE etat='3' ORDER BY
datevalid DESC";}
elseif ($ordre=='nom')
{$sel="SELECT numfiche,nom,datevalid from matable WHERE etat='3' ORDER BY
nomplante ASC";}
elseif ($ordre=='numfiche')
{$sel="SELECT numfiche,nom,datevalid from matable WHERE etat='3' ORDER BY
numfiche ASC";}
$req = mysql_query($sel) or die('Erreur SQL !'.$sel.'<br>'.mysql_error());
echo '<table><tr><td><a href="affichage.php?ordre=numfiche">Photo</a></td>
<td><a href="affichage.php?ordre=nom">Intitul&eacute;</a></td>
<td><a href="affichage.php?ordre=">Date d\'identification</a></td>
</tr>';
while ($data=mysql_fetch_assoc($req))
{
$numfiche=$data['numfiche'];
$nom=$data['nom'];
$datevalid=$data['datevalid'];
$dateident=dateendroit($datevalid);
$photo='photos/'.$numfiche.'_1.jpg';
$image = exif_thumbnail($photo, $larg, $haut, $type);
echo'<tr><td><a href="voirfiche.php?numfiche='.$numfiche.'"
target="_blank">';
// Si la vignette existe on l'affiche, sinon on met le numéro de la fiche
if ($image)
{echo '<img
src="data:image/png;base64,'.base64_encode($image).'"
width="'.$larg.'" height="'.$haut.'" alt="mini" />';}
else
{
echo $numfiche;
}
echo '</a></td>
<td>'.stripslashes($nom).'</td>
<td>'.$dateident.'</td></tr>';
}
echo'</table>

Jusqu'à présent, ce tableau ne comportait aucune image, il était donc vite
chargé bien que le nombre d'enregistrements soit important (il y avait
juste l'inconvénient d'un ascenseur à rallonge, pas très élégant et peu
pratique).
Avec les vignettes, je ne peux plus continuer comme ça, il faut que je
fasse des pages moins longues, par exemple d'une vingtaine ou d'une
trentaine de fiches) et que les utilisateurs puissent « naviguer » d'une
page à l'autre (sans perdre l'ordre de tri qu'ils ont choisi.
Je pense qu'il faut utiliser l'option LIMIT dans Mysql pour récupérer les
enregistrements par « paquets » mais ça ne m'amène pas bien loin...

J'imagine que c'est un problème simple et classique, mais je m'y paume
quand même. Votre aide sera la bienvenue...

--
Pascale

10 réponses

1 2 3
Avatar
Bruno Desthuilliers
Pascale a écrit :
(snip)

Je génère un zouli tableau comme suit :

$ordre=$_GET['ordre'];
// L'utilisateur a le choix de l'ordre d'affichage des fiches
if ($ordre=='')
{$sel="SELECT numfiche,nom,datevalid from matable WHERE etat='3' ORDER BY
datevalid DESC";}
elseif ($ordre=='nom')
{$sel="SELECT numfiche,nom,datevalid from matable WHERE etat='3' ORDER BY
nomplante ASC";}
elseif ($ordre=='numfiche')
{$sel="SELECT numfiche,nom,datevalid from matable WHERE etat='3' ORDER BY
numfiche ASC";}



Apprends à utiliser un switch case, et à ne pas te répéter:

$ordre=$_GET['ordre'];
switch ($ordre) {
case 'nom':
$order_by = "nomplante ASC";
break;
case 'numfiche':
$order_by = "numfiche ASC";
break;
default:
$order_by = "datevalid DESC";
break;
}

$sel "SELECT numfiche, nom, datevalid " .
"FROM matable " .
"WHERE etat='3' " .
"ORDER BY $order_by"
;

Comme ça, si tu dois modifier quelque chose, c'est plus simple...

(snip)

Jusqu'à présent, ce tableau ne comportait aucune image, il était donc vite
chargé bien que le nombre d'enregistrements soit important



(snip code)

Avec les vignettes, je ne peux plus continuer comme ça, il faut que je
fasse des pages moins longues, par exemple d'une vingtaine ou d'une
trentaine de fiches) et que les utilisateurs puissent « naviguer » d'une
page à l'autre (sans perdre l'ordre de tri qu'ils ont choisi.
Je pense qu'il faut utiliser l'option LIMIT



conjointement à OFFSET...

dans Mysql pour récupérer les
enregistrements par « paquets » mais ça ne m'amène pas bien loin...

J'imagine que c'est un problème simple et classique,



Oui, ça s'appelle une pagination.

mais je m'y paume
quand même. Votre aide sera la bienvenue...



Il faut utiliser limit et offset, et passer les valeurs concernées dans
les urls pour les récupérer à la requête (http) suivante. Bref, tes urls
doivent ressembler à:

affichage.php?ordre=numfiche&debut=XXX&combien=YYY

Après quoi tu utilises les valeurs $_GET['debut'] et $_GET['combien']
(après nettoyage of course pour éviter des injections SQL etc) pour les
valeurs LIMIT et OFFSET de ta requête SQL. Ou si tu choisis un
pagination 'fixe', tu codes le 'combien' (l'OFFSET) en dur (de
préférence comme constante symbolique) et tu ne passe que le 'debut' (le
LIMIT) dans les urls que tu mets avant et/ou après ton tableau et qui
permettent de naviguer dans la pagination...

HTH
Avatar
Emmanuel
Pascale a écrit :

Avec les vignettes, je ne peux plus continuer comme ça, il faut que je
fasse des pages moins longues, par exemple d'une vingtaine ou d'une
trentaine de fiches) et que les utilisateurs puissent « naviguer » d'une
page à l'autre (sans perdre l'ordre de tri qu'ils ont choisi.
Je pense qu'il faut utiliser l'option LIMIT dans Mysql pour récupérer les
enregistrements par « paquets » mais ça ne m'amène pas bien loin...




Il est effectivement possible d'utiliser l'option limit pour restreindre
l'affichage des parties de ton tableau. Note, néanmoins que limit peut
être très gourmand et peu optimal dans le cas d'un grand nombre
d'enregistrements.

Voir par exemple les tests fait par Damien Seguy:
http://www.nexen.net/articles/dossier/17611-mon_join_est_plus_rapide_que_ton_limit.php

Dans le cas que tu proposes, il pourrait être intéressant d'ajouter à
tes requêtes le limit a,b qui prend 2 valeurs. La première indique à
partir de quel enregistrement va commencer la récupération des données,
et la seconde le nombre d'enregistrements retournés.

Soit dans ton cas:

SELECT numfiche,nom,datevalid from matable WHERE etat='3' ORDER BY
datevalid DESC limit $deb, $nb_fiches_par_page

Le $nb_fiches_par_page ne pose pas de problème il suffit de
l'initialiser à la valeur de son choix en début de code.

Le $deb peut quand à lui etre associé à la page sur laquelle on est (en
admettant que le tableau se découpe en pages $page). Pour simplifier, on
peut aussi considérer que la première page vue est la page 0 (affichant
les $nb_fiches_par_page fiches), le suivante la 1 etc.

On aura: $deb=$page*$nb_fiches_par_page

Et bien il ne reste qu'à faire passer les numéros de page dans les liens
des boutons suivant et/ou précédent.

Par exemple:


<a href="affichage.php?ordre=$ordre&page=$prec">Précédent</a>
<a href="affichage.php?ordre=$ordre&page=$suiv">Suivant</a>


La valeur de l'ordre est conservé et transmise. Reste à déterminer
$prec, et $suiv

Si la page courante est appelée sans que $_GET['page'] existe (ou vaut
0), alors on est sur la première page (la 0) et donc il ne faut pas
afficher le lien précédent. $suiv vaut alors 1.

Si $_GET['page'] a été transmis alors $prec correspondra à
$_GET['page']-1 et $suiv à $_GET['page']+1

Il faudra tester aussi dans quel cas on n'affichage pas de bouton
Suivant (quand il n'y a plus de page après celle sur laquelle on est).

La formule (il y a peut être plus simple):

$page_maxÎil($nb_fiche/$nb_par_page)-1; devrait indiquer le nombre
maximales de pages dès lors qu'on connait le nombre de fiches (en
faisant un mysql_num_rows() par exemple.

En rassemblant ça, je pense que tu pourras faire un code qui te permette
d'afficher le tableau page par page.

--
Emmanuel
Avatar
CrazyCat
Pascale wrote:
{$sel="SELECT numfiche,nom,datevalid from matable WHERE etat='3' ORDER BY
nomplante ASC";}



Il te suffit de choisir un nombre d'items par page et de pouvoir
récupérer la page en cours:
<?
$items = 10;
(intval($_GET['page'])<1) ? $page = 1 : $page = intval($_GET['page']);
$sel="SELECT numfiche,nom,datevalid from matable WHERE etat='3' ORDER BY
nomplante ASC LIMIT ".($page - 1).", ".$items;
?>



--
Réseau IRC Francophone: http://www.zeolia.net
Aide et astuces webmasters : http://www.c-p-f.org
Communauté Francophone sur les Eggdrops: http://www.eggdrop.fr
Avatar
Pascale
Je me réponds à moi-même que j'ai trouvé, il me reste quand même à mettre
en bas de page un accès aux pages autres que celle qui est affichée, ça n'a
pas l'air si simple : j'ai plus de 60 pages, je ne peux pas aligner autant
de chiffres, il faut que j'en affiche par exemple 10 avec « pages
précédentes » et « pages suivantes » pour accéder aux autres.

--
Pascale
Avatar
Pascale
Merci à tous les trois, et, désolée, j'ai réellement cru que j'avais besoin
d'aide, mais finalement, j'étais arrivée à quelque chosede très similaire à
ce vous me conseillez.
Bruno a raison, je ne pense pas toujours à utiliser switch case, en fait,
je connais, mais je pense rarement à l'utiliser et c'est un tort. Par contre,
OFFSET m'est inconnu, faut que je me documente là-dessus.

Le résultat :
http://www.la-grille-verte.net/kekcestruc/kekvoirid.php

Ça casse pas 3 pattes à un canard, mais a priori ça convient.

... ce qui m'amène à une autre question : j'utilise les vignettes incluses
dans les exifs des photos ce qui est extrêmement pratique, mais elles sont
quelquefois manquantes (vieux appareils photo, plantes scannées
directement, logiciel de retouche d'image destructeurs...).
Si je veux générer et stocker une vignette à partir d'une photo uploadée
par un utilisateur, quelle est la manière la plus simple et efficace,
sachant que je veux que la solution retenue ne se casse pas la figure si je
change d'hébergeur ?

--
Pascale
Avatar
Olivier Miakinen
Le 11/09/2008 17:44, Pascale a écrit :

... ce qui m'amène à une autre question : j'utilise les vignettes incluses
dans les exifs des photos ce qui est extrêmement pratique, mais elles sont
quelquefois manquantes (vieux appareils photo, plantes scannées
directement, logiciel de retouche d'image destructeurs...).
Si je veux générer et stocker une vignette à partir d'une photo uploadée
par un utilisateur, quelle est la manière la plus simple et efficace,
sachant que je veux que la solution retenue ne se casse pas la figure si je
change d'hébergeur ?



Je pense que GD doit se trouver dans PHP chez à peu près tous les
hébergeurs :

http://fr.php.net/gd
http://fr.php.net/manual/fr/function.imagecopyresampled.php

Mais j'ai entendu dire que ImageMagick donnait de meilleurs résultats.
Vérifier son support chez les différents hébergeurs :

http://fr.php.net/manual/fr/book.imagick.php
Avatar
Pascale
Olivier Miakinen <om+ écrivait
news:48c93f1c$:

http://fr.php.net/gd
http://fr.php.net/manual/fr/function.imagecopyresampled.php

Mais j'ai entendu dire que ImageMagick donnait de meilleurs résultats.
Vérifier son support chez les différents hébergeurs :

http://fr.php.net/manual/fr/book.imagick.php



Question bête : est-ce que ces fonctions créent une vignette de manière
dynamique au moment de l'exécution du code, ou bien est-ce que la vignette
est créée et stockée dans le même répertoire que la photo?

Dans le cas qui m'intéresse, la qualité n'est pas primordiale, même si je
ne tiens évidemment pas à générer des vignettes toutes pourries (:

--
Pascale
Avatar
Olivier Miakinen
Le 12/09/2008 00:21, Pascale a écrit :

Question bête : est-ce que ces fonctions créent une vignette de manière
dynamique au moment de l'exécution du code, ou bien est-ce que la vignette
est créée et stockée dans le même répertoire que la photo?



Comme tu veux tu choises !

Si la vignette est censée être vue un certain nombre de fois, et étant
donné qu'elle ne prendra pas beaucoup de place sur le disque, je te
conseillerais bien de la créer et la stocker (par exemple dans le même
répertoire, mais pas forcément).

Par exemple, si c'est une image JPEG qui se trouve en "$chemin/$nom", tu
peux la sauver par : imagejpeg($image, "$chemin/vignettes/$nom").

Mais tu peux aussi faire un script qui te convertit l'image à la volée,
ce script commençant par header("image/jpeg") et se terminant par
imagejpeg($image).

Dans le cas qui m'intéresse, la qualité n'est pas primordiale, même si je
ne tiens évidemment pas à générer des vignettes toutes pourries (:



Oui, bien sûr. Je n'ai pas fait l'essai alors je ne peux pas te dire ce
que ça donnera, mais si j'en crois la doc ça devrait être de meilleure
qualité avec imagecopyresampled qu'avec imagecopyresized. Attention à
bien travailler tes images en « truecolor » plutôt qu'en « palette ».
Avatar
Olivier Miakinen
Le 12/09/2008 01:02, je répondais à Pascale :

[...] ce script commençant par header("image/jpeg") [...]



Ça ne risque pas de fonctionner. Nul doute que remplacer "image/jpeg"
par "Content-Type: image/jpeg" serait préférable.
Avatar
Pascale
Olivier Miakinen <om+ écrivait
news:48c9a4c8$:

[...] ce script commençant par header("image/jpeg") [...]



Ça ne risque pas de fonctionner. Nul doute que remplacer "image/jpeg"
par "Content-Type: image/jpeg" serait préférable.



Merci.

Pour répondre à ton message précédent, je pense qu'il serait plus simple
pour moi de sauvegarder les vignettes une fois pour toutes. J'imagine aussi
que le temps de chargement de la page serait plus court que si les
vignettes sont générées « à la volée » ?

--
Pascale
1 2 3