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

Langage PHP Discussion :

Problème fonction strtr ou str_replace


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 12
    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 : 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
     
    $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);

  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
    $msg n'est pas défini dans le code que tu nous montres.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 12
    Par défaut
    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 : Sélectionner tout - Visualiser dans une fenêtre à part
    $msg = htmlentities($_POST['input']);

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 12
    Par défaut
    et pour être encore plus complet!
    voici le contenu de $msg :

    ---------- Message en français ----------

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

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

    Non renseigné.

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


    Non renseigné.

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 12
    Par défaut
    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()" :

    ---------- Message en français ----------

    Bonjour

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

    Non renseigné.

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

    Non renseigné.
    et là avec strtr() :
    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

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 12
    Par défaut
    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 : 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
    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!!

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

Discussions similaires

  1. [RegEx] problème fonction str_replace
    Par askrim dans le forum Langage
    Réponses: 7
    Dernier message: 16/01/2013, 16h32
  2. problème fonction str_replace
    Par Sh4dow49 dans le forum Langage
    Réponses: 5
    Dernier message: 21/07/2008, 14h23
  3. Problème fonction strtr()
    Par cflo91 dans le forum Langage
    Réponses: 6
    Dernier message: 05/07/2007, 17h35
  4. Problème fonction et trigger sous 7.2
    Par anoukhan dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 22/06/2005, 23h53
  5. Réponses: 2
    Dernier message: 20/08/2004, 18h10

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