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

Macros et VBA Excel Discussion :

Explication de code [XL-2003]


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Inscrit en
    Janvier 2013
    Messages
    149
    Détails du profil
    Informations forums :
    Inscription : Janvier 2013
    Messages : 149
    Points : 63
    Points
    63
    Par défaut Explication de code
    Bonsoir,

    Quelqu'un pourrait-t-il m'expliquer, simplement, ce morceau de code ?
    En particulier, le passage souligné... Merci beaucoup !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub toto()
    Dim datechercher As String
    Dim i As Integer
    With Sheets("Feuil1")
        datechercher = Date
        For i = 17 To 47
            If CDate(.Cells(10, i)) = datechercher Then
                .Range(.Cells(11, i), .Cells(33, i)).Select
                Exit Sub
            End If
        Next i
    End With
    End Sub

  2. #2
    Membre régulier
    Homme Profil pro
    Passioné
    Inscrit en
    Août 2009
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Passioné
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2009
    Messages : 82
    Points : 116
    Points
    116
    Par défaut
    Tu cherches une date dans les colonnes (de 17 à 47) de la Feuil1.
    Si tu trouves cette date, tu sélectionnes la plage correspondante (entre les lignes 11 et 33).

  3. #3
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub toto()
    Dim datechercher As String 'voir avec l'aide "F1"
    Dim i As Integer 'voir avec l'aide "F1"
    With Sheets("Feuil1")
        datechercher = Date
        For i = 17 To 47 'on commence une boucle de 17 à 47
            If CDate(.Cells(10, i)) = datechercher Then 'donc 1ère boucle .cells(10,i) représente .cells(10,17) soit range("P10")
                .Range(.Cells(11, i), .Cells(33, i)).Select ' faire même déduction, on selectionne range("Q11:Q33")
                Exit Sub 'on sort du programme si la condition est remplie
            End If
        Next i 'on passe à la boucle suivante
    End With
    End Sub
    code qui ne sert pas à grand-chose, en l'état

    Edit :et qui peut être remplacé sans utiliser de boucle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub toto()
    Dim Ch As Range
    Set Ch = Range("Q17:AU17").Find(Date, LookIn:=xlValues)
    If Not Ch Is Nothing Then
      Range(Cells(11, Ch.Column), Cells(33, Ch.Column)).Select
    Else
      MsgBox "pas de correspondance trouvée"
    End If
    End Sub

  4. #4
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    1 733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 1 733
    Points : 2 553
    Points
    2 553
    Par défaut
    Hahaha Merci casefayere! Le code "useless" vient de moi..

  5. #5
    Membre du Club
    Inscrit en
    Janvier 2013
    Messages
    149
    Détails du profil
    Informations forums :
    Inscription : Janvier 2013
    Messages : 149
    Points : 63
    Points
    63
    Par défaut
    Bonjour,

    Merci pour votre aide casefayere. Le message à propos des correspondances est excellent. En revanche, la fonction de sélection ne fonctionne pas même lorsqu'elle le devrait (lorsque le mois est trouvé).

    Le code de EngueEngue fonctionne, mais je ne comprends vraiment pas l'histoire du For i = 17 To 47. D'accord, une boucle, mais une boucle de quoi ? Des cellules 17 à 47 ? Pourquoi ?

    Et si je veux l'utiliser ailleurs, je dois remplacer le 17 et le 47 ? Voilà ce n'est pas très clair dans ma tête en fait... Si pourriez m'expliquer comme à un enfant de 5 ans je prends !

  6. #6
    Membre régulier
    Homme Profil pro
    Passioné
    Inscrit en
    Août 2009
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Passioné
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2009
    Messages : 82
    Points : 116
    Points
    116
    Par défaut
    Comme indiqué dans mon premier message, 17 à 47 sont les n° de colonne (colonne Q à colonne AU)

  7. #7
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    1 733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 1 733
    Points : 2 553
    Points
    2 553
    Par défaut
    A = 1 B = 2 C = 3 .... Q = 17 .... AU = 47

  8. #8
    Membre du Club
    Inscrit en
    Janvier 2013
    Messages
    149
    Détails du profil
    Informations forums :
    Inscription : Janvier 2013
    Messages : 149
    Points : 63
    Points
    63
    Par défaut
    Super, je viens de comprendre merci beaucoup.
    En prime, j'ai trouvé en fouillant un peu comment afficher les numéros de colonnes au lieu de voir les lettres.

    Impeccable !

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

Discussions similaires

  1. Explication de code
    Par sacco dans le forum C
    Réponses: 2
    Dernier message: 13/04/2006, 00h13
  2. Explication de code
    Par claralavraie dans le forum Linux
    Réponses: 1
    Dernier message: 20/03/2006, 10h58
  3. Shell - Explication de code
    Par claralavraie dans le forum Linux
    Réponses: 13
    Dernier message: 13/01/2006, 17h03
  4. Explication de code - RE
    Par deedoo dans le forum Général Python
    Réponses: 23
    Dernier message: 29/07/2005, 15h00
  5. Explication de code simple
    Par Clad3 dans le forum OpenGL
    Réponses: 3
    Dernier message: 20/03/2005, 12h31

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