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 :

Recopier les données d'une cellule dans une autre


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    143
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Transports

    Informations forums :
    Inscription : Juin 2012
    Messages : 143
    Points : 93
    Points
    93
    Par défaut Recopier les données d'une cellule dans une autre
    Bonjour à tous,
    Mon soucis est le suivant :
    Dans la colonne D de la feuille1, chaque cellule comporte des données.
    J'aimerais recopier les données de la cellule D2 dans E2, D3 dans E3, etc... jusque D10000 dans E10000.
    Pour l'instant j'utilise :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sheets("Feuil1").Range("E2") = Sheets("Feuil1").Range("D2")
    Sheets("Feuil1").Range("E3") = Sheets("Feuil1").Range("D3")
    Sheets("Feuil1").Range("E4") = Sheets("Feuil1").Range("D4")
    Sheets("Feuil1").Range("E5") = Sheets("Feuil1").Range("D5")
    Sheets("Feuil1").Range("E6") = Sheets("Feuil1").Range("D6")
    Sheets("Feuil1").Range("E7") = Sheets("Feuil1").Range("D7")
    Sheets("Feuil1").Range("E8") = Sheets("Feuil1").Range("D8")
    Sheets("Feuil1").Range("E9") = Sheets("Feuil1").Range("D9")
    Sheets("Feuil1").Range("E10") = Sheets("Feuil1").Range("D10")
    et comme celà jusque 10000.
    J'aimerais trouver un code qui soit nettement plus léger et moins long pour que chaque cellule de la colonne E recoive les données de la celulle qui lui correspond dans la colonne D.

    Quelqu'un pourrait-il m'aiguiller ?
    Merci par avance.
    Laurent

  2. #2
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 645
    Points : 34 353
    Points
    34 353
    Par défaut
    salut,

    tu as plusieurs possibilités, mais la plus simple sera l'utilisation d'une boucle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    For i = 1 To 10000
    Sheets("Feuil1").Range("E" & i) = Sheets("Feuil1").Range("D" & i)
    Next i

  3. #3
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    143
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Transports

    Informations forums :
    Inscription : Juin 2012
    Messages : 143
    Points : 93
    Points
    93
    Par défaut Merci beaucoup mais...
    Merci beaucoup pour ta réponse jpcheck.
    J'ai utiliser ce que tu m'as donné de la manière suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub Recopier_Num_Activation()
    For i = 1 To 10000
    Sheets("Feuil1").Range("E" & i) = Sheets("Feuil1").Range("D" & i)
    Next i
    End Sub
    J'obtiens un message d'erreur qui me dit qu'il y a une erreur de compilation avec une variable non définie.
    Que puis-je y faire stp ?

    Merci encore

  4. #4
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 927
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 927
    Points : 28 920
    Points
    28 920
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Une autre solution.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub Copie()
     With ThisWorkbook.Worksheets("Feuil1")
     .Range("E2:E10000").Value = .Range("D2:D10000").Value
     End With
    End Sub
    Ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     .Range("E2:E10000").Formula = .Range("D2:D10000").Formula
    Si l'on souhaite garder les formules

  5. #5
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    143
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Transports

    Informations forums :
    Inscription : Juin 2012
    Messages : 143
    Points : 93
    Points
    93
    Par défaut C'est tout bon
    Merci à jpcheck et à Philippe, j'ai trouvé.

    En fait déclarer la variable est simple.
    Pour ceux qui suivent le poste, voilà la solution :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Sub Recopier_Num_Activation()
    Dim i As Long
    For i = 1 To 10000
    Sheets("Feuil1").Range("E" & i) = Sheets("Feuil1").Range("D" & i)
    Next i
    End Sub
    Laurent

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

Discussions similaires

  1. [Toutes versions] coller les données d'une plage d'une cellule dans une cellule d'une autre feuille[VBA]
    Par arthson dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 24/01/2012, 17h37
  2. [XL-2007] problème de codage en vba ("copie d'une partie d'une cellule dans une cellule vide")
    Par skipeemed dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 26/10/2010, 17h01
  3. [XL-2002] Macro de comparaison d'une cellule d'une feuille avec une cellule d'une autre feuille.
    Par steelydan dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/09/2010, 12h59
  4. Afficher une image dans une cellule d'une gridview
    Par guigui11 dans le forum ASP.NET
    Réponses: 3
    Dernier message: 13/09/2007, 10h18
  5. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48

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