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 :

Utilisation de la fonction "str_replace"


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    66
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 66
    Points : 59
    Points
    59
    Par défaut Utilisation de la fonction "str_replace"
    Bonjour,

    J'ai un petit problème, le problème est que si je selectionne Nord-Pas-de-Calais dans un select et après envoie il m'affiche AlsaceCentre du fait que Nord-Pas-de-Calais est égale à 17 comment remédier à cela en sachant que je ne peux pas modifier les chifres.


    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
     
    $region = $_POST['search'];
     
    $region = str_replace("1", "Alsace", $region);
    $region = str_replace("2", "Aquitaine", $region);
    $region = str_replace("3", "Auvergne", $region);
    $region = str_replace("4", "Basse-Normandie", $region);
    $region = str_replace("5", "Bourgogne", $region);
    $region = str_replace("6", "Bretagne", $region);
    $region = str_replace("7", "Centre", $region);
    $region = str_replace("8", "Champagne-Ardenne", $region);
    $region = str_replace("9", "Corse", $region);
    $region = str_replace("10", "Franche-Comte", $region);
    $region = str_replace("11", "Haute-Normandie", $region);
    $region = str_replace("12", "Ile-de-France", $region);
    $region = str_replace("13", "Languedoc-Roussillon", $region);
    $region = str_replace("14", "Limousin", $region);
    $region = str_replace("15", "Lorraine", $region);
    $region = str_replace("16", "Midi-Pyrenees", $region);
    $region = str_replace("17", "Nord-Pas-de-Calais", $region);
    $region = str_replace("18", "Pays-de-la-Loire", $region);
    $region = str_replace("19", "Picardie", $region);
    $region = str_replace("20", "Poitou-Charentes", $region);
    $region = str_replace("21", "Provence-Alpes-Cote-d-Azur", $region);
    $region = str_replace("22", "Rhone-Alpes", $region);
     
    echo '$region';

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Utilise plutot un tableau de correspondances :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $region = $_POST['search'];
     
    $tabRegion = array(
    1=>'Alsace',
    2=>'Aquitaine',
    3=>'Auvergne',
    ....
    );
    echo $tabRegion[$region];

  3. #3
    Expert confirmé
    Avatar de N1bus
    Homme Profil pro
    Dev. Web & OpenERP
    Inscrit en
    Janvier 2003
    Messages
    2 827
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Dev. Web & OpenERP
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2003
    Messages : 2 827
    Points : 5 673
    Points
    5 673
    Par défaut
    Bonjour,

    Pourquoi un str_replace() ?

    Si j'ai bien compris, $_POST['search'] et un chiffre ?

    Dans ce cas, utilise un switch() :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
    switch($_POST['search']){
     
       case "1" : $region = "Alsace"; break;
       case "2" : $region = "Aquitaine"; break;
       case "3" : $region = "Auvergne"; break;
       -
       - 
       -
    }
     
     echo $region;

  4. #4
    Membre éclairé
    Avatar de ProgVal
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2006
    Messages
    636
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2006
    Messages : 636
    Points : 752
    Points
    752
    Par défaut
    Bonjour,

    Il faut tout simplement traiter les régions à deux chiffres, et ensuite celles avec un seul chiffre.
    Tous les codes qui précèdent ce message sont donc incorrects; voici le bon:
    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
    $region = $_POST['search'];
     
    $region = str_replace("10", "Franche-Comte", $region);
    $region = str_replace("11", "Haute-Normandie", $region);
    $region = str_replace("12", "Ile-de-France", $region);
    $region = str_replace("13", "Languedoc-Roussillon", $region);
    $region = str_replace("14", "Limousin", $region);
    $region = str_replace("15", "Lorraine", $region);
    $region = str_replace("16", "Midi-Pyrenees", $region);
    $region = str_replace("17", "Nord-Pas-de-Calais", $region);
    $region = str_replace("18", "Pays-de-la-Loire", $region);
    $region = str_replace("19", "Picardie", $region);
    $region = str_replace("20", "Poitou-Charentes", $region);
    $region = str_replace("21", "Provence-Alpes-Cote-d-Azur", $region);
    $region = str_replace("22", "Rhone-Alpes", $region);
    $region = str_replace("1", "Alsace", $region);
    $region = str_replace("2", "Aquitaine", $region);
    $region = str_replace("3", "Auvergne", $region);
    $region = str_replace("4", "Basse-Normandie", $region);
    $region = str_replace("5", "Bourgogne", $region);
    $region = str_replace("6", "Bretagne", $region);
    $region = str_replace("7", "Centre", $region);
    $region = str_replace("8", "Champagne-Ardenne", $region);
    $region = str_replace("9", "Corse", $region);
     
    echo $region; //Il faut supprimer les apostrophes, sinon ça t'affichera non pas le contenu de la variable, mais $region
    Cordialement,
    ProgVal

  5. #5
    Expert confirmé
    Avatar de N1bus
    Homme Profil pro
    Dev. Web & OpenERP
    Inscrit en
    Janvier 2003
    Messages
    2 827
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Dev. Web & OpenERP
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2003
    Messages : 2 827
    Points : 5 673
    Points
    5 673
    Par défaut
    Tous les codes qui précèdent ce message sont donc incorrects;
    Vraiment ??

    Je crois que le tableau ou le switch() seront plus rapides.

  6. #6
    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
    Points : 44 155
    Points
    44 155
    Par défaut
    Tous les codes qui précèdent ce message sont donc incorrects;
    Si le but etait, a l'interieur d'un texte, de remplacer les chiffres par les noms des departements alors on pouvait faire comme tu proposes.
    Etant donné qu'il s'agit de transformer le retour d'un select, qui est a priori un simple nombre, nos propositions sont quand même plus adaptées.

    Je crois que le tableau ou le switch() seront plus rapides.
    D'ailleurs le switch est plus economique en mémoire que le tableau qui va stocker des informations pour rien.

  7. #7
    Membre éclairé
    Avatar de ProgVal
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2006
    Messages
    636
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2006
    Messages : 636
    Points : 752
    Points
    752
    Par défaut
    Oups, petite correction: le code de N1bus était correct.

    Désolé

  8. #8
    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
    Points : 44 155
    Points
    44 155
    Par défaut
    ah parce que le mien il pue ?

  9. #9
    Expert confirmé
    Avatar de N1bus
    Homme Profil pro
    Dev. Web & OpenERP
    Inscrit en
    Janvier 2003
    Messages
    2 827
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Dev. Web & OpenERP
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2003
    Messages : 2 827
    Points : 5 673
    Points
    5 673
    Par défaut
    Citation Envoyé par ProgVal Voir le message
    Oups, petite correction: le code de N1bus était correct.

    Désolé

    De même que le code de Sabotage !

    Tu devrais tester avant d'affirmer de fausses allégations

  10. #10
    Membre éclairé
    Avatar de ProgVal
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2006
    Messages
    636
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2006
    Messages : 636
    Points : 752
    Points
    752
    Par défaut
    Ah, effectivement, je suis bien le dernier des imbéciles... J'avais cru que tu faisais un remplacement à partir de cet array


  11. #11
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    66
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 66
    Points : 59
    Points
    59
    Par défaut
    Merci à vous pour ces codes

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

Discussions similaires

  1. Utilisation de la fonction str_replace
    Par turican2 dans le forum Langage
    Réponses: 5
    Dernier message: 11/10/2008, 12h45

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