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 :

code copier formule jusqu'à la dernière ligne


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2010
    Messages : 42
    Points : 41
    Points
    41
    Par défaut code copier formule jusqu'à la dernière ligne
    Bonjour,

    Je développe un outils afin de me ramener le CA réalisé avec l'un de nos client.
    Dans les données rapportées, j'ai une colonne "période" dont le format est "AAAAMM" que je transforme via VBA en "MMM-AA".

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ActiveCell.FormulaR1C1 = "=DATE(LEFT(RC[-1],4),RIGHT(RC[-1],2),1)"
    Je souhaiterais maintenant trouver un code pour que cette formule soit copiée jusqu'à la dernière ligne de mes données, sachant que je n'aurais pas dans blancs/trous dans ces données.

    J'avais penser utiliser quelque chose avec "Selection.End(xlUp/xlDown)" mais je ne sais pas trop comment faire.

    Merci pour toute l'aide que vous pourrez m'apporter

  2. #2
    Expert éminent sénior Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Points : 31 877
    Points
    31 877
    Par défaut
    Pour répondre à ta question
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Dim LastLig As Long
     
    With Sheets("Feuil1")   ' à adapter
       LastLig = .Cells(.Rows.Count, "A").End(xlUp).Row   'Colonne A données AAAAMM
       With .Range("B2:B" & LastLig)                      'Colonne B on récuppère
          .FormulaR1C1 = "=DATE(LEFT(RC[-1],4),RIGHT(RC[-1],2),1)"
          .NumberFormat = "mmm-yy"
       End With
    End With

  3. #3
    Expert éminent
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Points : 7 149
    Points
    7 149
    Billets dans le blog
    7
    Par défaut formules incrémentées
    Bonjour,

    Il te faut d'abord définir la zone qui accueillera ta formule.

    Je te propose ce code adapté éventuellement

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Sub Macro1()
     
    Dim act As Range, fin As Range
     
    '1ère cellule à droite de ta cellule active
     Set déb = ActiveCell.Offset(0, 1)
     
    'dernière cellule à droite de ta zone
     Set fin = Cells(Rows.Count, ActiveCell.Column).End(xlUp).Offset(0, 1)
     
    'formule appliquée à la zone définie
     Range(déb, fin).FormulaR1C1 = "=DATE(LEFT(RC[-1],4),RIGHT(RC[-1],2),1)"
     
    End Sub
    N'hésite pas à revenir pour plus de précisions.

Discussions similaires

  1. [XL-2007] Macro comment copier une formule jusqu'à la derniere ligne d'une col
    Par zaza45 dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 04/01/2012, 14h44
  2. scrollpanel non visible jusqu'à la dernière ligne
    Par cotede2 dans le forum Agents de placement/Fenêtres
    Réponses: 0
    Dernier message: 08/11/2009, 16h32
  3. [XL-2003] copier coller a la dernière ligne de la colonne
    Par bosk1000 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 03/11/2009, 16h54
  4. Copier Formule jusqu'à dernière ligne
    Par mattwarend dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 05/12/2008, 23h40
  5. Etendre ma formule jusqu'à la xième ligne
    Par benoitbs dans le forum Excel
    Réponses: 4
    Dernier message: 30/01/2008, 15h57

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