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 :

Plage de cellule variable [XL-2013]


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé Avatar de backx3
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2014
    Messages
    173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Yvelines (Île de France)

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

    Informations forums :
    Inscription : Octobre 2014
    Messages : 173
    Par défaut Plage de cellule variable
    Bonjour,
    Un nouveau problème s'ouvre à moi... :

    J'ai un code qui, si une ligne est modifiée, un caractère "?" est affiché dans la même ligne et dans la colonne A.
    En fonction de ce code, j'aimerais que dès que le caractère "?" est affiché en colonne A, sur la même ligne, que ça écrive une formule en colonne B.

    Mon problème, malgré mes recherches, je n'arrive pas à sélectionner une plage variable

    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
    Sub Date_MaJ()
     
        Dim F1 As Worksheet, cell As Range, NumCol As Integer, Col As Integer
        Dim NumLigne As Long, DerLigne As Long, Var As Variant
     
        'Défini la feuille "PlanEQM_TCR"
        Set F1 = Worksheets("PlanEQM_TCR")
     
        'Défini la dernière ligne
        DerLigne = Split(F1.UsedRange.Address, "$")(4)
     
        NumCol = 1
     
            'Pour toutes les lignes de la colonne 1, regarder où il y a le caractère "?",
            'et mettre la date de MaJ en colonne B et sur la même ligne
     
            For NumLigne = 1 To DerLigne
                Var = F1.Cells(NumLigne, NumCol)
     
                'Affichage console
                Debug.Print Var
     
                    Do While DerLigne <> 0
     
                    If Var = "?" Then
                    'Set Point = Range(Cells(NumLigne, Col)).Select 'Cette ligne de fonctionne pas
                    'Application.Goto reference = Range(NumLigne)'Celle ci non plus
                    'Cells(NumLigne, Col).Select 'Ne fonctionne toujours pas... J'aurais essayé pourtant ! :(
     
                    ActiveCell.Offset(0, 1).Select
                    ActiveCell.FormulaR1C1 = "=TODAY()"
     
     
                Else: Exit Do
                End If
                    Loop
            Next
        Set F1 = Nothing
     
     
     
    End Sub
    Quelqu'un saurait m'éclairer svp ?

  2. #2
    Membre confirmé Avatar de backx3
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2014
    Messages
    173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Yvelines (Île de France)

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

    Informations forums :
    Inscription : Octobre 2014
    Messages : 173
    Par défaut
    J'ai trouvé tout seul comme un grand !
    Je mets le code pour ceux qui auraient le même soucis (que le for):

    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
    For NumLigne = 1 To DerLigne
                Var = F1.Cells(NumLigne, NumCol)
     
                'Affichage console
                Debug.Print Var
     
                    Do While DerLigne <> 0
     
                    If Var = "?" Then
                    Point = Cells(NumLigne, 1).Select
     
                    ActiveCell.Offset(0, 1).Select
                    ActiveCell.FormulaR1C1 = "=TODAY()"
     
     
                Else: Exit Do
                End If
                    Loop
            Next

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

Discussions similaires

  1. Sélectionner une plage de cellules variables pour faire un graphique?
    Par drthodt dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 29/11/2007, 18h06
  2. Liste de diffusion Mail selon plage de cellule variable
    Par dguff dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 07/09/2007, 17h10
  3. Somme dépendant de plage de cellules variable
    Par Talieth dans le forum Excel
    Réponses: 4
    Dernier message: 23/04/2007, 10h37
  4. appliquer une macro a une plage de cellule variable
    Par johndeuf dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 10/11/2006, 16h18
  5. [VBA-E]Selection plage de cellules variable
    Par julien5 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 23/05/2006, 14h51

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