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 :

Groupement de codes postaux par zones


Sujet :

VBA Access

  1. #1
    Candidat au Club
    Femme Profil pro
    Ingénieur agronome
    Inscrit en
    Mai 2015
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur agronome
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Mai 2015
    Messages : 10
    Points : 4
    Points
    4
    Par défaut Groupement de codes postaux par zones
    Bonjour à tous,

    J'aimerais écrire un programme permettant d'automatiser le groupement de codes postaux en zones en suivant certains critères. Je pense avoir un algorithme potable, mais étant débutante il me manque malheureusement la traduction en langage VBA... J'ai quand même fait une tentative qui bien sûr ne fonctionne pas, je m'explique :

    J'ai une table sur laquelle tous mes calculs sont basés = DonneesCP. Elle regroupe les champs :
    - Codes Postaux = CP (texte)
    - Longitude en mètres = X (réel double)
    - Latitude en mètres = Y (réel doube)
    - Surface = ha_MT_RGA (réel double)
    - Nombre d'individus = nb_MT_RGA (entier long)
    - Distance (réel double) / Vide au départ
    - Attribution (T/F) / Vide au départ
    - Zone (entier long) / Vide au départ

    Mon objectif est de créer une zone en ajoutant les codes postaux de proche en proche jusqu'à ce que la zone atteigne une surface ou un nombre d'individus donné.
    Pour cela je procède en deux étapes, voici mon code :

    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
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
     
    Private Sub Commande0_Click()
    'Commande0 = un bouton pour déclencher la procédure. Le formulaire sera plus élaboré plus tard...
     
    'Appels
     
    Dim MAJDistance_CP_SQL As String, MAJAttribution_CP_SQL As String, MAJZone_CP_SQL As String
     
    Dim CPini As String, Xini As Double, Yini As Double
    Dim NbEnregistrements As Integer, i As Integer
    Dim X As Double, Y As Double
    Dim Distance As Double
     
    Dim NumZone As Integer
    Dim Smt As Double, Smtmax As Double
    Dim Nbmt As Integer, Nbmtmax As Integer
    Dim Distancemin As Double
     
    '1. Calcul de la distance de chaque CP au CP initial
     
    CPini = "'" & InputBox("Code postal de départ :") & "'"
    Xini = DLookup("[DonneesCP].[X]", "[DonneesCP]", "[DonneesCP].[CP] = '" & CPini & "'") 'Erreur de syntaxe : opérateur absent dans [DonneesCP].[CP] = "11090"
    Yini = DLookup("[DonneesCP].[Y]", "[DonneesCP]", "[DonneesCP].[CP] = '" & CPini & "'")
     
    NbEnregistrements = DCount("[DonneesCP].[CP]", "[DonneesCP]")
     
    'Calcul pour chaque enregistrement
    For i = 1 To NbEnregistrements
     
        X = [DonneesCP].[X](i) 'Syntaxe fausse très certainement, je cherche à récupérer le X de l'enregistrement i
        Y = [DonneesCP].[Y](i)
     
        ' Calcul de la distance : petit Pythagore...
        Distance = ((Xini - X) ^ 2 + (Yini - Y) ^ 2) ^ (1 / 2)
     
        ' MAJ du champ Distance de l'enregistrement i
        MAJDistance_CP_SQL = "UPDATE [DonneesCP] SET [DonneesCP].[Distance] = Distance" & _
                    "WHERE [DonneesCP].[CP] = [DonneesCP].[CP](i)"
        DoCmd.RunSQL MAJDistance_CP_SQL, dbFailOnError
     
    Next i
     
    '2. Calcul de la Zone 1
     
    NumZone = 1
     
    Smtmax = InputBox("Surface zone :")
    Nbmtmax = InputBox("Effectif de la zone :")
     
    Smt = DLookup("[DonneesCP].[ha_MT_RGA]", "[DonneesCP]", "[DonneesCP].[CP] = '" & CPini & "'")
    Nbmt = DLookup("[DonneesCP].[nb_MT_RGA]", "[DonneesCP]", "[DonneesCP].[CP] = '" & CPini & "'")
     
    Do While Smt <= Smtmax And Nbmt <= Nbmtmax
     
        Distancemin = DMin("[DonneesCP].[Distance]", "[DonneesCP]", "[Donnees].[Attribution] <> TRUE")
     
        MAJAttribution_CP_SQL = "UPDATE [DonneesCP] SET [DonneesCP].[Attribution] = TRUE" & _
                    "WHERE [DonneesCP].[Distance]= Distancemin"
        DoCmd.RunSQL MAJAttribution_CP_SQL, dbFailOnError
     
        MAJZone_CP_SQL = "UPDATE [DonneesCP] SET [DonneesCP].[Zone] = NumZone" & _
                    "WHERE [DonneesCP].[Distance]= Distancemin"
        DoCmd.RunSQL MAJZone_CP_SQL, dbFailOnError
     
        Smt = Smt + DLookup("[DonneesCP].[ha_MT_RGA]", "[DonneesCP]", "[DonneesCP].[Distance] = Distancemin")
        Nbmt = Nbmt + DLookup("[DonneesCP].[nb_MT_RGA]", "[DonneesCP]", "[DonneesCP].[Distance] = Distancemin")
     
    Loop
     
    End Sub
    J'ai donc besoin de votre aide pour appliquer à ce code un langage VBA correct... Merci d'avance !

  2. #2
    Membre chevronné
    Inscrit en
    Août 2006
    Messages
    1 588
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 1 588
    Points : 2 178
    Points
    2 178
    Par défaut
    Bonjour,
    Effectivement ce n'est pas bon
    Remplacer la boucle For par ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
     Dim t As DAO.Recordset
     Set t = CurrentDb.OpenRecordset("DonneesCP")
     Do Until t.EOF
        x = t!x
        y = t!y
     
     .......................
     
        t.MoveNext
     Loop
     t.Close
    Ouverture de la table
    lecture des données pour chaque enregistrement
    t.EOF = plus d'enregistrement
    Fermeture de la table

  3. #3
    Candidat au Club
    Femme Profil pro
    Ingénieur agronome
    Inscrit en
    Mai 2015
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur agronome
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Mai 2015
    Messages : 10
    Points : 4
    Points
    4
    Par défaut
    Super, merci pour ta réponse.
    Je ne peux malheureusement pas faire tourner la boucle car le début de mon code n'est pas fonctionnel... Sais-tu d'où vient le message d'erreur pour Dlookup ? J'ai eu beau chercher sur le net toutes les formules suivent le même modèle que la mienne.

    Penses-tu également que j'ai d'autres erreurs de langage dans le reste du code ?

Discussions similaires

  1. Combos en cascade - Code Postaux commençant par 0
    Par AsTN94 dans le forum Ext JS / Sencha
    Réponses: 2
    Dernier message: 31/05/2011, 13h41
  2. [Spip] [Spip immo] Recherche par ville et codes postaux
    Par realkilla dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 1
    Dernier message: 31/08/2009, 14h29
  3. Obtenir les données pour avoir une carte de France par codes postaux
    Par lilsandy dans le forum SIG : Système d'information Géographique
    Réponses: 0
    Dernier message: 08/06/2009, 13h46
  4. Tri par Codes Postaux + Noms d'entreprises
    Par matperino dans le forum Langage SQL
    Réponses: 2
    Dernier message: 21/07/2005, 14h04
  5. Réponses: 2
    Dernier message: 18/10/2003, 14h42

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