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

VBA Access Discussion :

Quotes dans une variable [AC-2002]


Sujet :

VBA Access

  1. #1
    Expert éminent sénior
    Avatar de Domi2
    Homme Profil pro
    Gestionnaire
    Inscrit en
    Juin 2006
    Messages
    7 194
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : Suisse

    Informations professionnelles :
    Activité : Gestionnaire
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 194
    Points : 16 044
    Points
    16 044
    Par défaut Quotes dans une variable
    Bonjour,

    J'utilise les bases de cette contribution de Philben pour afficher des points dans Google Maps.

    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
    34
    35
    36
    37
    38
    39
    Case "frmMenuGeneral"
     
            Me.ctlNavigateur.Navigate CurrentProject.Path & "\Système\" & strNomPage
     
            strSql = "SELECT tblCommunes.CommuneNom, tblCommunes.CommuneLat, tblCommunes.CommuneLong, Count(tblLogements.LogImm) AS CompteDeLogImm " & _
                     "FROM (tblCommunes INNER JOIN tblImmeubles ON tblCommunes.CommuneId = tblImmeubles.ImmNumeroCommune) INNER JOIN tblLogements " & _
                     "ON tblImmeubles.ImmId = tblLogements.LogImm GROUP BY tblCommunes.CommuneNom, tblCommunes.CommuneLat, tblCommunes.CommuneLong " & _
                     "ORDER BY tblCommunes.CommuneNom;"
     
            Set db = CurrentDb
            Set rst = db.OpenRecordset(strSql)
     
            If rst.BOF Then
     
                MsgBox "il n'y a pas d'enregistrements"
     
                GoTo Exit_Sub
     
            End If
     
            Do Until rst.EOF
     
                dblLat = rst("CommuneLat")
                dblLong = rst("CommuneLong")
     
                strLigne1 = rst("CommuneNom")
                strLigne2 = rst("CompteDeLogImm") & " logements"
     
                Do
     
                DoEvents
     
                Loop While Me.ctlNavigateur.busy
     
                AddPoint dblLat, dblLong, 10, "" & strLigne1 & ",<br> " & strLigne2 & ""
     
                rst.MoveNext
     
            Loop
    Procédure AddPoint :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    'Ajoute un point GPS dans Google map. Si zoom = 0 la carte n'est pas centrée
    Private Sub AddPoint(ByVal dblLat As Double, ByVal dblLong As Double, _
                         Optional ByVal bytZoom As Byte = 0, _
                         Optional ByVal strMessage As String)
     
        'Déclaration de la variable
        Dim strScript As String
     
        strScript = "affMsg(" & str(dblLat) & "," & str(dblLong) & "," & bytZoom & ",'" & strMessage & "');"
     
        Me.ctlNavigateur.Document.parentWindow.execScript strScript, "JScript"
     
    End Sub
    Cela fonctionne, mis à part le fait que si la variable strMessage contient des <'>, j'ai une erreur (voir pièce jointe):

    J'ai essayé de doubler mes quotes ou d'encadrer ma variable avec Chr(34), mais cela ne fonctionne pas.

    Pour l'instant, j'ai remplacé les <'> par des espaces avec Replace(), mais c'est à moitié satisfaisant.

    Si quelqu'un a déjà résolu ce problème...

    Merci d'avance.

    Domi2

  2. #2
    Membre habitué Avatar de jimay
    Profil pro
    Inscrit en
    Août 2006
    Messages
    146
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Val d'Oise (Île de France)

    Informations forums :
    Inscription : Août 2006
    Messages : 146
    Points : 178
    Points
    178
    Par défaut
    salut

    on dirait que cette erreur arrive dans une page html, as tu essayé de remplacer tes quotes par les caractères spéciaux ?

    celui de ' est &apos;

    a+

  3. #3
    Expert éminent sénior
    Avatar de Domi2
    Homme Profil pro
    Gestionnaire
    Inscrit en
    Juin 2006
    Messages
    7 194
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : Suisse

    Informations professionnelles :
    Activité : Gestionnaire
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 194
    Points : 16 044
    Points
    16 044
    Par défaut
    Merci beaucoup jimay

    Effectivement, il s'agit bien d'une page html...

    Ca ne fonctionne pas avec "&apos;" ou je ne sais pas comment le protéger dans ma variable.

    Mais la piste que tu m'as donné m'a permis d'étendre mes recherches.

    Et cela fonctionne parfaitement en protégeant la quote avec un anti-slash.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Replace(strMaVariable, "'", "\'")
    Encore merci pour ton aide.

    Domi2

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

Discussions similaires

  1. Quote dans une requete...
    Par Isildur dans le forum Langage SQL
    Réponses: 6
    Dernier message: 20/06/2006, 10h57
  2. quotes dans une variable
    Par requiemforadream dans le forum ASP
    Réponses: 3
    Dernier message: 09/05/2005, 09h55
  3. Résultat d'une requête dans une variable...
    Par Hoegaarden dans le forum Bases de données
    Réponses: 6
    Dernier message: 28/04/2004, 13h51
  4. Réponses: 6
    Dernier message: 24/07/2003, 12h39
  5. [langage] Extraire un block dans une variable multiligne
    Par |DUCATI| DesMo dans le forum Langage
    Réponses: 9
    Dernier message: 11/02/2003, 14h56

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