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

Développement Windows Discussion :

Remplacer plusieurs caractères


Sujet :

Développement Windows

  1. #1
    Membre à l'essai
    Homme Profil pro
    génie logiciel
    Inscrit en
    Mars 2012
    Messages
    113
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : génie logiciel

    Informations forums :
    Inscription : Mars 2012
    Messages : 113
    Points : 21
    Points
    21
    Par défaut Remplacer plusieurs caractères
    Bonjour;
    je voudrai utiliser la fonction replace pour remplacer plusieurs caractère et non pas un:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Replace(TextBox5.Text, "'", """", " ", 0, vbTextCompare)
    ,
    la chaine de caractère est comme suit:IM 'C' "ILOT" ......
    Merci.

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Tu veux remplacer tous les ' par des " ? La méthode Replace convient parfaitement, mais à mon avis tu ne l'utilises pas comme il faut... les 3 derniers paramètres sont optionnels, et avec les valeurs que tu as mises ça remplace un seul caractère à la fois.

    Comme ça, ça remplace tout :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Replace(TextBox5.Text, "'", """")

  3. #3
    Membre à l'essai
    Homme Profil pro
    génie logiciel
    Inscrit en
    Mars 2012
    Messages
    113
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : génie logiciel

    Informations forums :
    Inscription : Mars 2012
    Messages : 113
    Points : 21
    Points
    21
    Par défaut
    le truc c'est que ma chaîne contient plusieurs caractères tels que des ',",)... que je voudrais tous remplacer par un espace je sais pas si vous voyez ce que je veux dire

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Dans ce cas tu peux utiliser une expression régulière :

    Code VB.NET : Sélectionner tout - Visualiser dans une fenêtre à part
    Regex.Replace(TextBox5.Text, "[""']", " ")

    S'il y a d'autres caractères à remplacer, ajoute les entre les crochets. Attention, certains caractères ont un sens particulier dans une expression régulière : ?!()[]*+ (entre autres). Dans ce cas il faut les préfixer par un backslash. Par exemple, si tu voulais remplacer aussi les "+" et les "?" :

    Code VB.NET : Sélectionner tout - Visualiser dans une fenêtre à part
    Regex.Replace(TextBox5.Text, "[""'\+\?]", " ")

  5. #5
    Membre à l'essai
    Homme Profil pro
    génie logiciel
    Inscrit en
    Mars 2012
    Messages
    113
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : génie logiciel

    Informations forums :
    Inscription : Mars 2012
    Messages : 113
    Points : 21
    Points
    21
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Try
                        'insertion dans le table compteur
                        com = New SqlCommand("insert into ANOMR(N_ORD_ECO,SOUS_QUART,CIL,QUART,NOM_CLT,AV_ACC,PORTE,RUE,N_CPT_DEPO,N_SERIE,DER_IND_LU,TP_CAL,MAR_DEPO,DATE_DEPO,ANOM,AG)values('" & ComboBox1.SelectedItem & "','" & Replace(TextBox1.Text, "'", " ", 1, vbTextCompare) & "','" & Val(TextBox2.Text) & "','" & Replace(TextBox3.Text, "'", " ", 1, vbTextCompare) & "','" & Replace(TextBox4.Text, "'", " ", 1, vbTextCompare) & "','" & Replace(TextBox5.Text, "'", " ") & "','" & Val(TextBox6.Text) & "','" & Replace(TextBox7.Text, "'", " ", 1, vbTextCompare) & "','" & Val(TextBox8.Text) & "','" & Val(TextBox9.Text) & "','" & Val(TextBox10.Text) & "','" & Val(TextBox11.Text) & "','" & TextBox12.Text & "','" & d & "','" & ComboBox2.SelectedItem & "','" & ComboBox3.SelectedItem & "');", con)
                        com.ExecuteNonQuery()
                        MsgBox("Anomalie enregistrée", MsgBoxStyle.OkOnly)
                    Catch ex As Exception
                        MsgBox("Erreur d'insertion des données:" & ex.ToString)
                    End Try
    le message d'erreur que j ai et le suivant:
    syntaxe incorrecte vers 'A', ce A se trouve dans la chaine de caractére suivante:"ILOT" HAJJAR IM 'A' APT RES.
    merci

  6. #6
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    C'est quoi ce code illisible ?
    Tu sais que tu peux mettre des variables intermédiaires, tu n'es pas obligé de tout écrire sur une seule ligne de 15km...

    Donc si je comprends bien, tu voulais remplacer les caractères pour les mettre dans une requête SQL ? Ce n'est pas comme ça qu'il faut faire... Il faut utiliser des requêtes paramétrées. Regarde ce tutoriel pour des explications :

    http://webman.developpez.com/article...rameter/vbnet/

    Ou encore cette FAQ:

    http://dotnet.developpez.com/faq/asp...onet_reqparams

Discussions similaires

  1. Réponses: 5
    Dernier message: 08/09/2014, 15h07
  2. [XL-2010] Problème pour remplacer plusieurs caractères avec Mid
    Par PPN83 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 08/10/2013, 16h52
  3. remplacement de caractère sur plusieurs feuilles
    Par magicfrom dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 21/05/2008, 09h59
  4. Remplacé des caractères UTF8 erronés dans plusieurs fichiers
    Par evaisse dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 31/03/2007, 23h18
  5. Comment remplacer plusieurs caractères dans une chaîne?
    Par Antigonos Ier Gonatas dans le forum Général Python
    Réponses: 5
    Dernier message: 16/06/2006, 16h04

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