Précédent   Forum des professionnels en informatique > PHP > Langage > Fonctions
Fonctions Forum d'entraide sur les fonctions PHP. Avant de poster -> FAQ fonctions et Sources diverses
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 13/01/2011, 13h22   #1
Invité de passage
 
Inscription : novembre 2009
Messages : 12
Détails du profil
Informations forums :
Inscription : novembre 2009
Messages : 12
Points : 2
Points : 2
Par défaut Problème fonction strtr ou str_replace

Bonjour à tous!

voilà comme vous l'imaginez...j'ai un problème!!!lol!

le contexte est simple....

j'ai un texte stocké dans une variable $msg que je récupère à partir d'un post...
ensuite je crée de nouvelles variables $civil, $nom et $pre qui stockent des données que je vais chercher dans ma base.

jusque là pas de problème, tout fonctionne.

ensuite j'aimerais modifier des occurences de chaines de caractères dans $msg par ces variables là...donc j'utilise soit strtr ou str_replace, mais ni l'un ni l'autre ne fonctionne...aucun ne lit mes variables...pourtant les fonctions fonctionnent si je met des chaines de caractères en brut...mais le but serait qu'il soit dynamique lol!
et là je cale, je comprend pas pourquoi ca ne marche pas...

si quelq'un peut m'aider, je susi preneur...

Code :
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
 
$req3 = "SELECT * FROM con_contact c, eml_email e WHERE c.con_id = e.eml_id_con AND con_id_pro ='".$data2['pro_id']."' AND con_principal = '1' AND eml_defaut = '1' AND eml_actif = '1'";
			$result3 = mysql_query($req3) or die("<br/>Requête invalide 3: " . mysql_error() ."");
 
			$data3 = mysql_fetch_array($result3);
			/*****REMPLACER LES VALEURS TEMPLATES PAR LES DONNEES DU CONTACT******/
 
			$civil = $data3['con_civilite'];
			$nom = $data3['con_nom'];
			$pre = $data3['con_prenom'];
 
			echo $civil.' '.$nom.' '.$pre;
 
			/*$trans = array(/*"--CIVIL--" => $civil,"--PRENOM--" => $pre,"--NOM--" => $nom*///);
			/*$trans["--CIVIL--"] = $civil ;
			$trans["--PRENOM--"] = $pre ;
			$trans["--NOM--"] = $nom ;
			$trans["Bonjour"] = 'Salut' ;
			$msg = strtr($msg, $trans);*/
 
			//$msg = strtr($msg, "--CIVIL--", $civil);
			$msg = str_replace("--CIVIL--", $civil, $msg);//ca coince....:(
 
			$msg = str_replace("--NOM--", $nom, $msg);
			//$msg = strtr($msg, "--NOM--", $nom);
 
			$msg = str_replace("--PRE--", $pre, $msg);
			//$msg = strtr($msg, "--PRE--", $pre);
chris911 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/01/2011, 14h39   #2
Modérateur
 
Avatar de sabotage
 
Homme Vincent
Inscription : juillet 2005
Messages : 14 929
Détails du profil
Informations personnelles :
Nom : Homme Vincent

Informations forums :
Inscription : juillet 2005
Messages : 14 929
Points : 16 381
Points : 16 381
$msg n'est pas défini dans le code que tu nous montres.
sabotage est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/01/2011, 14h58   #3
Invité de passage
 
Inscription : novembre 2009
Messages : 12
Détails du profil
Informations forums :
Inscription : novembre 2009
Messages : 12
Points : 2
Points : 2
Oui, je l'ai oublié..
Comme je le disais, il contient du texte saisi dans un formulaire que je récupère avant tout le reste biensûr.

Code :
$msg = htmlentities($_POST['input']);
chris911 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/01/2011, 15h00   #4
Invité de passage
 
Inscription : novembre 2009
Messages : 12
Détails du profil
Informations forums :
Inscription : novembre 2009
Messages : 12
Points : 2
Points : 2
et pour être encore plus complet!
voici le contenu de $msg :

Citation:
---------- Message en français ----------

Bonjour --CIVIL-- --NOM-- --PRE--

---------- Message en anglais ----------

Non renseigné.

---------- Message en troisième langue ----------


Non renseigné.
chris911 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/01/2011, 15h04   #5
Invité de passage
 
Inscription : novembre 2009
Messages : 12
Détails du profil
Informations forums :
Inscription : novembre 2009
Messages : 12
Points : 2
Points : 2
lol désolé pour le nombre de post mais j'essaie d'être le plus complet possible pour que vous puissiez m'éclairer...

voilà ce que j'obtiens avec "str_replace()" :

Citation:
---------- Message en français ----------

Bonjour

---------- Message en anglais ----------

Non renseigné.

---------- Message en troisième langue ----------

Non renseigné.
et là avec strtr() :
Citation:
lllllllllllll sessage en français lllllllllllllll

Bonjour llle.eLll llscsll lln_rll

llllllllllllllllllll sessage en anglais llllllllllllllllllll

son renseigné.

llllllllllllllllllll sessage en troisième langue llllllllllllllllllll

son renseigné.
==> ici on voit apparaître un peut les variables mais pas du tout comme il le faudrait...lol
chris911 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/01/2011, 14h41   #6
Invité de passage
 
Inscription : novembre 2009
Messages : 12
Détails du profil
Informations forums :
Inscription : novembre 2009
Messages : 12
Points : 2
Points : 2
Après plusieurs heures de réflexions de tests et de re-tests j'ai réussi à corriger mon problème!!!!
donc je vous met le bout de code correspondant qui change ma vie! lol!Pour ceux qui un jour rencontrerons ce problèmes!

Code :
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
33
 
$msg = htmlentities($_POST['input']);
 
for($c=0;$c<$nbCon;$c++){
 
			$msg2 = $msg;
 
			$data2 = mysql_fetch_array($result2);
 
 
			$req3 = "SELECT * FROM con_contact c, eml_email e WHERE c.con_id = e.eml_id_con AND con_id_pro ='".$data2['pro_id']."' AND con_principal = '1' AND eml_defaut = '1' AND eml_actif = '1'";
			$result3 = mysql_query($req3) or die("<br/>Requête invalide 3: " . mysql_error() ."");
 
			$data3 = mysql_fetch_array($result3);
			/*****REMPLACER LES VALEURS TEMPLATES PAR LES DONNEES DU CONTACT******/
 
 
			$con_id = $data3['con_id'];
			$civil = $data3['con_civilite'];
			$nom = $data3['con_nom'];
			$pre = $data3['con_prenom'];
 
			$trans = array();
			$trans["--CIVIL--"] = $civil ;
			$trans["--PRE--"] = $pre ;
			$trans["--NOM--"] = $nom ;
 
 
			if($con_id != ''){
 
				$msg2 = html_entity_decode(stripcslashes(strtr($msg2, $trans)));
 
			}
voilà!bonne continuation à tous!!
chris911 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/01/2011, 14h45   #7
Modérateur
 
Inscription : septembre 2010
Messages : 7 101
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 101
Points : 8 466
Points : 8 466
pouruqoi tu fais un stripcslashes et un html_entity_decode ? et un htmlentities sur ton input, pareil pourquoi une boucle et mettre ton mysql_fetch_array($result2) dedan ??? y'a plein de truc bidouillé la c'est pas claire comme code
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 01
Vieux 14/01/2011, 15h33   #8
Invité de passage
 
Inscription : novembre 2009
Messages : 12
Détails du profil
Informations forums :
Inscription : novembre 2009
Messages : 12
Points : 2
Points : 2
c'est juste un bout de code de mon fichier entier, c'est normal que tu vois peut-être pas le but de mon code mais bon vu que c'est pour le boulot je vais pas caler tout mon fichier...

pour moi le plus important c'est que ça marche mais si tu veux le refaire tu peux y aller!
chris911 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/01/2011, 16h54   #9
Modérateur
 
Inscription : septembre 2010
Messages : 7 101
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 101
Points : 8 466
Points : 8 466
Citation:
Envoyé par chris911 Voir le message
c'est juste un bout de code de mon fichier entier, c'est normal que tu vois peut-être pas le but de mon code mais bon vu que c'est pour le boulot je vais pas caler tout mon fichier...

pour moi le plus important c'est que ça marche mais si tu veux le refaire tu peux y aller!
j'imagine le pire pour le reste
si t'aime bien comme ça c'est le principal ...
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 01
Vieux 14/01/2011, 17h42   #10
Invité de passage
 
Inscription : novembre 2009
Messages : 12
Détails du profil
Informations forums :
Inscription : novembre 2009
Messages : 12
Points : 2
Points : 2
Citation:
Envoyé par stealth35 Voir le message
j'imagine le pire pour le reste
si t'aime bien comme ça c'est le principal ...
c'est marrant les gens qui commentent pour rien dire une fois qu'on a plus besoin d'eux! mais bon si t'as une meilleure solution "plus propre" comme tu dit pourquoi tu la met pas pour les prochains?
chris911 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/01/2011, 17h55   #11
Modérateur
 
Inscription : septembre 2010
Messages : 7 101
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 101
Points : 8 466
Points : 8 466
Citation:
Envoyé par chris911 Voir le message
c'est marrant les gens qui commentent pour rien dire une fois qu'on a plus besoin d'eux! mais bon si t'as une meilleure solution "plus propre" comme tu dit pourquoi tu la met pas pour les prochains?
te vexe pas, si t'en t'en sort comme ça t'en mieux.
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 16h48.


 
 
 
 
Partenaires

Hébergement Web