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 :

copier des cellule d'une feuille vers une autre feuille


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
    Janvier 2008
    Messages
    171
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 171
    Par défaut copier des cellule d'une feuille vers une autre feuille
    bonjour tout le monde.

    depuis hier j'arrive pas à resoudre mon probleme, alors s'il vous plait s'il y a qlq qui puisse m'aider je lui serai tres reconaissante.

    mon probleme est le suivant:
    je veux copier quelque resultats de la feuille STATISTIQUESCONSO vers la feuille STATCONSOLIDEES. alors il faut à chaque fois que j'execute ce code il me copie la case C1 dans la première cellule vide de la colonne A.
    si ça marche je vais le generaliser. c'est à dire copie la case B31 dans la première cellule vide de la colonne B...

    mais le probleme rien que ce code , il me genere cette message: erreur définie par l'application ou par l'objet? et le cursseur se positionne vers la ligne suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("A1").End(xlDown).Offset(1, 0).Select ' selectionner la première cellule vide de la colonne A
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    'copier quelque resultat de la feuille STATISTIQUESCONSO vers la feuille STATCONSOLIDEES
    Worksheets("STATISTIQUESCONSO").Activate ' activer la feuille source
    Range("C1").Copy                         'copier le résultat de la cellule C1
    Worksheets("STATCONSOLIDEES").Activate   'activer la feuille de distination
    Range("A1").End(xlDown).Offset(1, 0).Select ' selectionner la première cellule vide de la colonne A
    ActiveCell.Insert                    'coller le resultat dans la cellule selectionnée
    merci par avance

  2. #2
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    Bonjour,

    Pour copier ta cellule C1 tu peux essayer soit (copier tout : valeur, format, formule)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets("STATISTIQUESCONSO").Range("C1").Copy Sheets("STATCONSOLIDEES").Range("A65535").End(xlUp)(2)
    soit (copier uniquement la valeur)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets("STATCONSOLIDEES").Range("A65535").End(xlUp)(2) = Sheets("STATISTIQUESCONSO").Range("C1")

  3. #3
    Membre confirmé
    Inscrit en
    Janvier 2008
    Messages
    171
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 171
    Par défaut
    j'ai trouvé une piste:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets("STATCONSOLIDEES").Range("A65536").End(xlUp).Offset(1, 0) = Sheets("STATISTIQUESCONSO").Range("C1").Value
    je vous tiendrai au courant de la suite

    merci fring
    je viens de voir ta proposition, merci beacoup, je vais l'exploiter pour generaliser (l'adapter à mon cas) merci encore fring

    fring est ce que tu peux m'expliquer stp la différence entre le code que j'ai trouvé offset et ton code (2)? le résultat est le meme! merci

  4. #4
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    (2) permet de décaler d'une ligne vers le bas, (3) de 2 lignes, (4) de 3 lignes, etc...c'est juste parce que je suis fainéant et que c'est plus court à encoder... mais il est plus facile, et plus clair à la lecture du code, d'utiliser Offset pour exécuter un décalage.

    Offset(x, y) :
    x = nombre de ligne (positif = décalage vers le bas, négatif = vers le haut)
    y = nombre de colonne (positif = décalage vers la droite, négatif = vers la gauche

    Exemple Range("A1").Offset(5, 3) va t'amener dans la cellule "C6"

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 28/01/2015, 15h39
  2. [XL-2007] Dupliquer des formules d'une feuille vers les autres feuilles du classeur
    Par capi81 dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 13/07/2014, 17h25
  3. Réponses: 2
    Dernier message: 17/02/2014, 12h41
  4. Copier des cellules de fichiers mensuels vers une master spreadsheet
    Par aerolulu dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 13/10/2009, 19h13
  5. Pb copier une valeur d'une textbox vers une cellule
    Par whykiki dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 09/12/2007, 12h49

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