Accueil > Forum > > > > Fusion de tableaux multidimensions en fonction d'une clé
Fusion de tableaux multidimensions en fonction d'une clé
jeudi 25 août 2005 à 19:53:13 |
Fusion de tableaux multidimensions en fonction d'une clé

nikoo3
|
Salut à tous, j'ai un problème en PHP que je n'arrive pas à résoudre: j'ai deux tableaux séprarés qui ont 5 dimensions, dont une qui est une date. Je dois fusionner ces deux tableaux, par date croissante, pour ensuite afficher l'unique tableau résultat. Je n'y arrive pas. J'ai tenté de me servir da la fonction array_multisort, mais sans succès... Quelqu'un peut il m'aider?
Merci beaucoup.
PS: si ce que je dis n'a pas été clair, n'hésitez pas à m'écrire à nicube à free.fr
|
|
jeudi 25 août 2005 à 20:10:19 |
Re : Fusion de tableaux multidimensions en fonction d'une clé

coucou747
|
moi je pensais à un foreach puis un sort...
vas sur php.net et cherches array
|
|
jeudi 25 août 2005 à 20:36:16 |
Re : Fusion de tableaux multidimensions en fonction d'une clé

nikoo3
|
Je vais peut être préciser en fait ce que je cherche :
Comment trier un tableau multidimension en fonction d'une des colones ? EX : classement d'un tableau a deux dimension en fonction de la date NICO 22/10/2005 JEAN 23/01/2005 JULIE 01/07/2005 ==> MARC 06/05/2005 MARC 06/05/2005 JULIE 01/07/2005 JEAN 23/01/2005 NICO 22/10/2005
Je pense que ca doit être faisable en appelant une fonction. Faire une boucle rend la complexité de l'algo énorme.
Merci encore
|
|
jeudi 25 août 2005 à 20:46:38 |
Re : Fusion de tableaux multidimensions en fonction d'une clé

coockiesch
|
Pour trier, tu devrais regarder: [ Lien ]
Je viens de faire:
function compare( $a, $b )
{
if( $a[1] == $b[1] )
return 0;
return ( $a[1] > $b[1] ) ? -1 : 1;
}
$donnees = array( array( 'NICO', '22/10/2005' ), array( 'JULIE',
'01/07/2005' ), array( 'MARC', '06/05/2005' ), array( 'JEAN',
'23/01/2005' ) );
foreach( $donnees as $value )
echo $value[0] . ' ' . $value[1] . '<br />';
echo '<br />';
uksort( $donnees, "compare" );
foreach( $donnees as $value )
echo $value[0] . ' ' . $value[1] . '<br />';
Et ca affiche:
NICO 22/10/2005
JULIE 01/07/2005
MARC 06/05/2005
JEAN 23/01/2005
JEAN 23/01/2005
MARC 06/05/2005
JULIE 01/07/2005
NICO 22/10/2005
@++
R@f
www.allpotes.ch: Photos, humour, vidéos, gags, ... "On dit que seulement 10 personnes au monde comprenaient Einstein. Personne ne me comprends. Suis-je un génie???"
|
|
jeudi 25 août 2005 à 20:56:05 |
Re : Fusion de tableaux multidimensions en fonction d'une clé

J_G
|
Salut, ceci ammène cela :
array_multisort
(PHP 4, PHP 5) array_multisort -- Tri multi-dimensionnel de tableaux
Descriptionbool array_multisort ( array ar1 [,
mixed arg [, mixed ... [, array ...]]] )
Cette fonction retourne TRUE en cas de succès,
FALSE en cas d'échec.
array_multisort() sert à trier simultanément plusieurs
tableaux, ou bien à trier un tableau multi-dimensionnel, suivant l'une ou
l'autre de ses dimensions.
|
|
jeudi 25 août 2005 à 22:58:33 |
Re : Fusion de tableaux multidimensions en fonction d'une clé

nikoo3
|
Merci pour ton aide coockiesch , mais la solution ne marche pas
En effet, pour l'exemple donné ca fonctionne, mais en implémentant la solution j'ai eu des problèmes... Si tu prends le code suivant
<?php function compare( $a, $b ) { if( $a[1] == $b[1] ) return 0;
return ( $a[1] > $b[1] ) ? -1 : 1; }
$donnees = array( array( 'NICO', '22/01/2005' ), array( 'JULIE', '01/01/2005' ), array( 'MARC', '06/01/2005', ), array( 'JEAN', '23/01/2005' ) ); foreach( $donnees as $value ) echo $value[0] . ' ' . $value[1] . '<br />';
echo '<br />';
uksort( $donnees, "compare" ); foreach( $donnees as $value ) echo $value[0] . ' ' . $value[1] . '<br />'; ?>
(Le meme avec des dates dans le meme mois)
le résultat n'est pas bon:
NICO 22/01/2005 JULIE 01/01/2005 MARC 06/01/2005 JEAN 23/01/2005
JEAN 23/01/2005 MARC 06/01/2005 JULIE 01/01/2005 NICO 22/01/2005
et je ne sais pas trop pourquoi...
Je suis donc toujours sans solution... Merci de votre aide
|
|
jeudi 25 août 2005 à 23:42:57 |
Re : Fusion de tableaux multidimensions en fonction d'une clé

coockiesch
|
Salut!
Il doit prendre ca comme des chaînes de caractères, faudrait utiliser
des timestamp. TU peux aps générer les timestamp des dates avant de
classer tout ca?
@++
R@f www.allpotes.ch: Photos, humour, vidéos, gags, ... "On dit que seulement 10 personnes au monde comprenaient Einstein. Personne ne me comprends. Suis-je un génie???"
|
|
vendredi 26 août 2005 à 16:33:00 |
Re : Fusion de tableaux multidimensions en fonction d'une clé

nikoo3
|
Réponse acceptée !
Ca n' rien donné de mieux avec les timestamp. Je suis passé par un tri à bulle : <?php function DateToNumber($a) { return mb_strcut ($a ,6 ,4).mb_strcut ($a ,3 ,2).mb_strcut ($a ,0 ,2); } function NumberToDate($a) { return mb_strcut ($a ,6 ,2)."/".mb_strcut ($a ,4 ,2)."/".mb_strcut ($a ,0 ,4); }
function Tri_A_Bulle ($Tab, $NbElem) {
$k = $NbElem; while ($k > 1) { for ($i = 0; $i < ($NbElem - 1); $i++) { echo "<br>".$i .": ".$Tab[$i][1];
echo "<br>";echo $i+1;echo ": "; echo $Tab[$i+1][1]; echo "<br>"; //$i--; if ($Tab[$i][1] > $Tab [$i+1][1]) { //Permuter ($Tab[$i], $Tab[$i + 1]); $Tmp = $Tab[$i]; $Tab[$i]=$Tab[$i+1]; $Tab[$i+1]= $Tmp; } } $k--; } return $Tab; }
function DateToNumber($a) { $chaine = substr ($a ,6 ,4).substr ($a ,3 ,2).substr ($a ,0 ,2); return $chaine; } function NumberToDate($a) { return substr ($a ,6 ,2)."/".substr ($a ,4 ,2)."/".substr ($a ,0 ,4); }
$donnees = array( array( 'NICO', DateToNumber('22/01/2005') ), array( 'JULIE', DateToNumber('01/01/2005') ), array( 'MARC', DateToNumber('06/01/2005') ), array( 'JEAN', DateToNumber('23/01/2005') ) ); foreach( $donnees as $value ) echo $value[0] . ' ' . $value[1] . '<br />';
echo '<br />';
$donnees = Tri_A_Bulle( $donnees,sizeof($donnees)); foreach( $donnees as $value ) echo $value[0] . ' ' . NumberToDate($value[1] ). '<br />'; ?>
Ca pourra toujours servir a quelqu'un... Cependant cette solution est tres lourde, et je conseille a ceux qui ont de gros tableaux de passer par un autre tri. Merci en tout cas de vos réponse. Nico.
|
|
Cette discussion est classée dans : fonction, tableaux, clé, fusion, multidimensions
Répondre à ce message
Livres en rapport
|
Derniers Blogs
POUR RAPPEL ! LES SPéCIFICATIONS DES PROTOCOLES OFFICE ET SHAREPOINT SONT DISPONIBLES SUR MSDNPOUR RAPPEL ! LES SPéCIFICATIONS DES PROTOCOLES OFFICE ET SHAREPOINT SONT DISPONIBLES SUR MSDN par neodante
Quelle est le point commun entre : Microsoft il y a 10 ans et Apple aujourd'hui ? Réponse: avoir une politique de protocoles propriétaires et fermés :) Car pour rappel (si si je vous assure c'est important de le rappeler), la majorité des spécifications e...
Cliquez pour lire la suite de l'article par neodante JOYEUX ANNIVERSAIRE NIXJOYEUX ANNIVERSAIRE NIX par ebartsoft
Souhaitons un bon et joyeux anniversaire à notre hôte à tous, Nix.
Je ne le répéterais jamais assez mais sans lui rien ne serait possible. Il défit en permanence les lois de la gravité et comme il le dit si bien, si tu lui fais confiance ça devra...
Cliquez pour lire la suite de l'article par ebartsoft IMAGINE CUP 2012, MAKE A SIGN EN FINALEIMAGINE CUP 2012, MAKE A SIGN EN FINALE par junarnoalg
Voilà qui est fait, la nouvelle est officielle ! L'équipe belge "Make a Sign" va au pays des kangourous défendre son projet dans la catégorie Software Design. http://www.imaginecup.com/CompetitionsContent/Competition/WorldwideFinalists.aspx V...
Cliquez pour lire la suite de l'article par junarnoalg KINECT 1.5 IS OUT !KINECT 1.5 IS OUT ! par Vko
La version 1.5 du Kinect For Microsoft vient tout juste de sortir ! Plein de nouveautés: Tracking de squelette en Near Mode Détection en position assise Détection faciale avec un SDK dédié Documentation et des guideline (enfin) Un out...
Cliquez pour lire la suite de l'article par Vko LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) par richardc
Mise à jour des Web API du 14 Mai
Réservez dès maintenant votre journée du 20 juin pour le Windows Azure Dev Camp 2012 à Paris
Mise à jour de Team Foundation Service
MechCommander 2 sur Windows 8
Entity Framework 5 Release Candidate e...
Cliquez pour lire la suite de l'article par richardc
Logiciels
sDEVIS-FACTURES vlPRO (8.1.0.3)SDEVIS-FACTURES VLPRO (8.1.0.3)sDEVIS-FACTURES vlPRO a été mis au point pour les particuliers, créateurs, entrepreneurs, artisa... Cliquez pour télécharger sDEVIS-FACTURES vlPRO 974 Application Server (12.2.4.6)974 APPLICATION SERVER (12.2.4.6)Développez de puissantes applications dans un environnement de 'cloud computing', clusterisé, séc... Cliquez pour télécharger 974 Application Server vPicture (1.4.2.1)VPICTURE (1.4.2.1)Avec vPicture, hébergez vos images facilement et rapidement.
vPicture est un utilitaire simple, ... Cliquez pour télécharger vPicture Easy-Planning (2.2.1.6)EASY-PLANNING (2.2.1.6)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté au... Cliquez pour télécharger Easy-Planning COM-BACKUP (2.0)COM-BACKUP (2.0)
COM-BACKUP est un logiciel de sauvegarde qui permet de planifier les sauvegardes de vos dossiers ...
Cliquez pour télécharger COM-BACKUP
|