begin process at 2012 05 27 19:35:42
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Divers

 > PARCOURS DE TABLEAU À L'AIDE D'ATTRIBUTS HTML "NAME

PARCOURS DE TABLEAU À L'AIDE D'ATTRIBUTS HTML "NAME


 Information sur la source

 Description

Alors voici une petite source qui permet d'atteindre et modifier une valeur d'un array à l'aide d'une string formatée comme un attribute html "name" :
<?php
$value =& array_thru('user[login]', $_POST);
?>

ou bien d'un array contenant les clés ordonnées de la moins à la plus profonde :
<?php
$value =& array_thru(array('user','login' ), $_POST);
?>

Source

  • <?php
  • function &array_thru($selectors, &$a, $useNext = true)
  • {
  • // passage de name[name2] vers array('name','name2');
  • if(is_string($selectors))
  • $selectors = explode('[',str_replace(']','',$selectors));
  • if(!sizeof($selectors))
  • return $a;
  • // On récupère la première clé
  • $selector = array_shift($selectors);
  • if(isset($a[$selector]))
  • return array_thru($selectors, $a[$selector]);
  • // Recherche dans les sous array name[0][name2], name[1][name2]...
  • $set = null;
  • if($useNext && isset($a[0][$selector])){
  • $set = array();
  • foreach($a as $k => $v){
  • $e =& array_thru($selectors, $a[$k][$selector], $useNext);
  • if(!is_array($e)){
  • $set[] = &$e;
  • continue;
  • }
  • foreach($e as $n => $v){
  • $set[] = &$e[$n];
  • }
  • }
  • }
  • return $set;
  • }
  • ?>
<?php 
 
	function &array_thru($selectors, &$a, $useNext = true) 
	{ 
		//	passage de name[name2] vers array('name','name2'); 
		if(is_string($selectors)) 
			$selectors	=	explode('[',str_replace(']','',$selectors)); 
		
		if(!sizeof($selectors)) 
			return	$a; 
		
		//	On récupère la première clé 
		$selector	=	array_shift($selectors); 
		
		if(isset($a[$selector])) 
			return	array_thru($selectors, $a[$selector]); 
		
		//	Recherche dans les sous array name[0][name2], name[1][name2]... 
		$set	 =	null; 
		if($useNext && isset($a[0][$selector])){ 
			$set	=	array(); 
			foreach($a as $k => $v){ 
				$e	=&	array_thru($selectors, $a[$k][$selector], $useNext); 
				if(!is_array($e)){ 
					$set[]	=	&$e; 
					continue; 	
				} 
				foreach($e as $n => $v){
					$set[]	=	&$e[$n]; 
				} 
			} 
		} 
		
		return	$set; 
	}
 
?>

 Conclusion

e troisième paramètre vous permet de définir si lorsqu'une clé n'est pas trouvé il faut tenter de chercher dans le niveau inférieur. Ça peut s'avérer pratique avec les formulaires contenant des nom du type : "user[0][name]". En recherchant user[name] un tableau contenant user[0][name], user[1][name]... sera renvoyé.


 Sources du même auteur

FORM, ORM POUR FORMULAIRE
CLASS MOTEUR DE TEMPLATE PHP5
VÉRIFIER LES CHAMPS OBLIGATOIRES D'UN FORMULAIRE

 Sources de la même categorie

Source avec une capture MODULE JOOMLA 1.5 NOW LISTENING par Alcantornet
Source avec Zip Source avec une capture UPLOAD CENTER par basssem81
Source avec Zip COMPTEUR DE CLIQUE PHP AVEC JQUERY par devgoneti
Source avec Zip LIVRE D'OR SIMPLE (POUR DÉBUTANT) par devgoneti
Source avec Zip SCRIPT TRAVAUX POUR VOTRE SITE par FleuryK

 Sources en rapport avec celle ci

FONCTION RECURSIVE DE DOSSIERS par tefa24600
Source avec Zip EXÉCUTER DES REQUETE STYLE SQL SUR UN ARRAY par prince418
DÉTERMINATION DU CHEMIN D'INDEXAGE MENANT À UNE VALEUR DANS ... par 8Tnerolf8
Source avec Zip XML ET TABLEAUX : UNE CLASSE COMPLÈTE QUI CONVERTIT UN DOCUM... par DaCodeManiak
Source avec une capture UNE PETITE FONCTION POUR AFFICHER LES TABLEAUX PHP par bletous

Commentaires et avis

Aucun commentaire pour le moment.

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

tri tableau 2 dimensions [ par lebobby ] Bonjour je voudrais savoir comment je pourrais faire pour trier ce tableau :$tab[0]=array("i"=&gt;"23", "c" =&gt; "rge", "date" =&gt;'2002-08-03 12:00 [MySQL] Sauvegarde d'un tableau dans une table [ par cedvoyage ] Bonjour,J'aimerais sauvegarder un tableau (multimensionnel) dans ma base MySQL.Or quand j'essaye je n'ai que 'Array' de marquer dans le champ de ma ta probleme array tableau [ par guiguipumpkin ] bonjour,je ne trouve pas la fonction php qui permet de supprimer un element d'un tableau array, suivant un indice iun peu comme array_shift mais en po parcours de tableau et récupération de valeurs [ par chouchou1 ] Salut à tous, Je voudrais parcourir un tableau et placer chaque valeur que je rencontre dans une variable différente, est-ce que c est possible? une Fonction callback et classes [ par malalam ] &nbsp;Salut :-)J'ai un petit soucis : je veux utiliser array_filter() dans une fonction membre d'une classe.J'ai defini ma fonction callback dans cett Tableau (array) (pour les pros du PHP) [ par jockos ] Bonjour,J'ai 2 questions très techniques auxquel je n'ai trouvé AUCUNE réponse sur les nombreux sites et manuels PHP.Est-ce que les élements d'un tabl Tableau array etc... [ par Cestmoi ] J'affiche des données de la facon suivante :foreach($server-&gt;rules as $key =&gt; $value) { echo $key." = ".$value."&lt;br&gt;"; } Charger un array depuis mysql [ par mdog ] bonjour, je cherche a charger depuis mysql un tableau array pour pouvoir l'integrer dans une page, seulement je ne sais pas coment faire, avec ma syta incrementation difficile [ par charly25 ] bonjou ou bonsoir (je suis plus tres sur...)j'essaye actuellement de lier des menus deroulants (la selection dans l'un agit sur l'autre et vice versa) Problème de tableau Array [ par sebmayer ] Bonjour,voil&#224; j'ai un gros prbl&#232;me, ca fait deux jours que je cherche, et je n'ai trouv&#233; la solution nul part...j'ai un formulaire avec


Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,577 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales