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 :

copie de cellules d'une feuille vers une autre


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Novembre 2012
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 12
    Points : 15
    Points
    15
    Par défaut copie de cellules d'une feuille vers une autre
    Hello world !

    je cherche à copier les cellules d'une feuille A vers une feuille B.
    lorsque je fais la copie de deux cellules , cela marche correctement , en revanche dès lors je veux aller au delà de 3 cellules , vba me génère une erreur :" nombre d'arguments incorrect ou affectation des propriétés incorrecte "
    Pouvez-vous m'aidez s'il vous plait !

    note: la ligne 35 marche
    la ligne 37 ne marche pas.

    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
    Sub TraitementNomenclature()
     
    'les variables
    Dim Article As String
    Dim NumRows As Integer
    Dim NbCells As Integer
    Dim j, x As Integer
     
    ' les objets
    Dim Cellule As Range
    Dim wshO As Excel.Worksheet
    Dim wshD As Excel.Worksheet
     
    ' instantiation
    Set wshO = Application.ThisWorkbook.Worksheets("Part")
    Set wshD = Application.ThisWorkbook.Worksheets("Feuil1")
     
    With wshD
     
        NbCells = Application.WorksheetFunction.CountA(Feuil1.Range("$A:$A"))
     
        For i = 1 To NbCells
     
            If Left(Cells(i, 1), 2) = "18" Or Left(Cells(i, 1), 2) = "19" Then
               Article = Cells(i, 1)
               'Niveau
               Cells(i, 13) = "0"
               wshO.Activate
               NumRows = Range("A2", Range("A2").End(xlDown)).Rows.Count
                      For j = 1 To NumRows
                            If Cells(j, 1) = Article Then
                                'copier cellule E,F,G de la feuille "Part" vers les cellules J,K,L de la feuille "Feuil1"
                                With wshO
                                     'cette ligne marche correctement
                                    'wshD.Range(wshD.Cells(i, 10), wshD.Cells(i, 11)).Value = .Range(.Cells(j, 5), .Cells(j, 6)).Value
                                    ' celle-ci génère une erreur : nombre d'arguments incorrect ou affectation des propriétés incorrecte !
                                    wshD.Range(wshD.Cells(i, 10), wshD.Cells(i, 11), wshD.Cells(i, 12)).Value = .Range(.Cells(j, 5), .Cells(j, 6), .Cells(j, 7)).Value
     
                                End With
                             End If
                      Next
            End If
     
            If i <> 1 Then
              'UNIT_OF_MEASURE: default "EA"
              Cells(i, 14) = "EA"
            End If
     
        Next
    End With
    End Sub
    cordialement,

    Henri

  2. #2
    Expert éminent sénior
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 207
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 207
    Points : 14 362
    Points
    14 362
    Par défaut
    Bonjour,

    Quand tu mets une virgule entre deux cellules, cela corresppond à ":". Il faut donc indiquer la première et la dernière cellule :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    wshD.Range(wshD.Cells(i, 10), wshD.Cells(i, 12)).Value = .Range(.Cells(j, 5), .Cells(j, 7)).Value

  3. #3
    Membre à l'essai
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Novembre 2012
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 12
    Points : 15
    Points
    15
    Par défaut
    Merci beaucoup Daniel, j'ai intégré ta correction et mon code marche maintenant !
    Mais , j'ai une interrogation :
    comment fait-on si la copie ne concerne pas des cellules contiguës ?
    cela n'est pas mon cas, mais on peut bien imaginer qu'on veuille copier les cellules A,B,D de la feuille "A" vers les cellules A,C,F de la feuille "B" , dans ce cas comment faire ?


    cordialement,

    Henri

  4. #4
    Expert éminent sénior
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 207
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 207
    Points : 14 362
    Points
    14 362
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    wshD.Range("J" & i & ",L" & i).Value = .Range("E" & j & ",G" & j).Value

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

Discussions similaires

  1. Réponses: 14
    Dernier message: 11/03/2014, 09h01
  2. Transférer une ligne d'une feuille vers une autre feuille
    Par ElPibeOro dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 23/04/2012, 10h20
  3. Déplacer une image d'une feuille vers une autre dans un fichier Excel
    Par helenaide dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 03/10/2011, 14h27
  4. [XL-2007] copier une ligne d'une feuille vers une autre feuille
    Par scarfunk dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 27/05/2010, 22h18
  5. Macro Copier données d'une feuille vers une feuille cible
    Par La Zélie dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 08/09/2008, 10h01

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