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 :

Comment faire un ScrollRow [XL-2002]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mai 2008
    Messages
    145
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 145
    Par défaut Comment faire un ScrollRow
    Bonjour a tous

    J'ai une formule que je veux appliquer a toutes les cellules de la colonne.
    Avec l'enregistreur de macro, ca ma sorti à partir de la dernière cellule lors de mon essai, mais s'il y en a plus au deuxième essai, la macro arrete au nombre du premier. Que puis-je faire pour résoudre mon probleme
    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
    Range("H2").Select
        ActiveCell.FormulaR1C1 = "=DATEDIF(RC[-1],RC[-2],""y"")"
        Range("H2").Select
        Selection.AutoFill Destination:=Range("H2:H65535"), Type:=xlFillDefault
        Range("H2:H65535").Select
        ActiveWindow.ScrollRow
        ActiveWindow.ScrollRow = 62
        ActiveWindow.ScrollRow = 61
        ActiveWindow.ScrollRow = 60
        ActiveWindow.ScrollRow = 59
        ActiveWindow.ScrollRow = 58
        ActiveWindow.ScrollRow = 57
        ActiveWindow.ScrollRow = 56
        ActiveWindow.ScrollRow = 55
        ActiveWindow.ScrollRow = 54
        ActiveWindow.ScrollRow = 53
        ActiveWindow.ScrollRow = 52
        ActiveWindow.ScrollRow = 51
        ActiveWindow.ScrollRow = 50
        ActiveWindow.ScrollRow = 49
        ActiveWindow.ScrollRow = 48
        ActiveWindow.ScrollRow = 47
        ActiveWindow.ScrollRow = 46
        ActiveWindow.ScrollRow = 45
        ActiveWindow.ScrollRow = 44
        ActiveWindow.ScrollRow = 43
        ActiveWindow.ScrollRow = 42
        ActiveWindow.ScrollRow = 41
        ActiveWindow.ScrollRow = 40
        ActiveWindow.ScrollRow = 39
        ActiveWindow.ScrollRow = 38
        ActiveWindow.ScrollRow = 37
        ActiveWindow.ScrollRow = 36
        ActiveWindow.ScrollRow = 35
        ActiveWindow.ScrollRow = 34
        ActiveWindow.ScrollRow = 33
        ActiveWindow.ScrollRow = 32
        ActiveWindow.ScrollRow = 31
        ActiveWindow.ScrollRow = 30
        ActiveWindow.ScrollRow = 29
        ActiveWindow.ScrollRow = 28
        ActiveWindow.ScrollRow = 27
        ActiveWindow.ScrollRow = 25
        ActiveWindow.ScrollRow = 24
        ActiveWindow.ScrollRow = 23
        ActiveWindow.ScrollRow = 22
        ActiveWindow.ScrollRow = 21
        ActiveWindow.ScrollRow = 19
        ActiveWindow.ScrollRow = 18
        ActiveWindow.ScrollRow = 17
        ActiveWindow.ScrollRow = 15
        ActiveWindow.ScrollRow = 14
        ActiveWindow.ScrollRow = 13
        ActiveWindow.ScrollRow = 11
        ActiveWindow.ScrollRow = 10
        ActiveWindow.ScrollRow = 9
        ActiveWindow.ScrollRow = 8
        ActiveWindow.ScrollRow = 7
        ActiveWindow.ScrollRow = 6
        ActiveWindow.ScrollRow = 5
        ActiveWindow.ScrollRow = 4
        ActiveWindow.ScrollRow = 3
        ActiveWindow.ScrollRow = 2
        ActiveWindow.ScrollRow = 1
        Range("I2").Select
        ActiveCell.FormulaR1C1 = "=RC[-1]<60"
        Range("I2").Select
        Selection.AutoFill Destination:=Range("I2:I88"), Type:=xlFillDefault
        Range("I2:I88").Select

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Bonsoir

    A priori
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Range("H2:H65535").formulaR1C1="=DATEDIF(RC[-1],RC[-2],""y"")"
    Range("I2:I88").formulaR1C1="=RC[-1]<60"
    Mais c'est loin d'être le top de placer une formule sur autant de lignes...

    Quel est le but recherché?
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  3. #3
    Membre confirmé
    Inscrit en
    Mai 2008
    Messages
    145
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 145
    Par défaut
    ouin... tu as drolement raccourci mon code (je suis pas terrible et j'y vais comme je peux), je vais essayer
    Je n'ai pas tout compris mais je vais essayer demain matin
    merci pour ce code
    je te tiens au courant dans cette discussion
    à demain

  4. #4
    Membre confirmé
    Inscrit en
    Mai 2008
    Messages
    145
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 145
    Par défaut
    Super ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Range("H:H65535").FormulaR1C1 = "=DATEDIF(RC[-1],RC[-2],""y"")"
    Range("I2:I88").FormulaR1C1 = "=RC[-1]<60"


    Mais si je veux que ca arrete à la dernière données ??

    (j'avais mis jusqu'à 65355 parce que je ne sais pas comment faire pour arrêter à ma dernière données, moi dans la vie je travaille sur crystal report, mais je fais parfois des macros pour automatiser quelques affaires, mon code est lourd, je sais, mais cela a le mérite de fonctionner, mon boss sais pas que mon code est lourd du moment que ca fonctionne)

  5. #5
    Membre émérite
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    682
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 682
    Par défaut
    Bonjour,

    Pour avoir la dernière ligne non vide de la colonne H, il faut faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dl = Range("H65536").end(xlUp).row
    Et donc, tu pourras alors écrire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("H1:H" & dl).FormulaR1C1 = "=DATEDIF(RC[-1],RC[-2],""y"")"
    Et voilà, c'est plus léger

  6. #6
    Membre confirmé
    Inscrit en
    Mai 2008
    Messages
    145
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 145
    Par défaut
    Ca le fait seulement à la première ligne pas au ligne suivante.

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

Discussions similaires

  1. [VB6][impression]Comment faire des effets sur les polices ?
    Par le.dod dans le forum VB 6 et antérieur
    Réponses: 11
    Dernier message: 08/11/2002, 10h31
  2. comment faire evoluer ma base vers interbase6
    Par toure32 dans le forum InterBase
    Réponses: 5
    Dernier message: 23/10/2002, 10h59
  3. Réponses: 8
    Dernier message: 18/09/2002, 03h20
  4. Comment faire pour mettre l'ecran en veille ?
    Par March' dans le forum MFC
    Réponses: 6
    Dernier message: 29/08/2002, 14h25
  5. Comment faire pour créer un bitmap
    Par GliGli dans le forum C++Builder
    Réponses: 2
    Dernier message: 24/04/2002, 15h41

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