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 :

Probleme d' ActiveSheet.Paste [XL-2003]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    32
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 32
    Par défaut Probleme d' ActiveSheet.Paste
    Bonjour,

    Débutant en VBA, j'ai un problème dans ma procédure, elle ne fonctionne qu'une fois sur 3 voir moins , je bug au niveau de l'ActiveSheet.Paste en rouge.

    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
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    Sheets("SYSTEMATIQUE").Select
    
    Sheets("SYSTEMATIQUE").Unprotect Password:="remi"
    ActiveSheet.Unprotect Password:="remi"
    
    Columns("A:V").AutoFilter
    
    Sheets("SYSTEMATIQUE").Unprotect Password:="remi"
    ActiveSheet.Unprotect Password:="remi"
    
    'aller rechercher la systématique
    
    Dim numérosyst As String
    Dim celluletrouveesyst As Range
    Dim lignesyst As Integer
    Dim colsyst As Integer
    
    numérosyst = SM_Box
    
    Set celluletrouveesyst = Range("A:A").Find(numérosyst, lookat:=xlWhole)
    
    If celluletrouveesyst Is Nothing Then
    MsgBox "Numéro de systématique non valide"
    Exit Sub
    End If
    
    lignesyst = celluletrouveesyst.Row
    colsyst = celluletrouveesyst.Column
    
    ' Remplacer la date de derniere intervention
    
    Range("P" & lignesyst) = CDate(Date_sold_Box.Value)
    
    ' Remplacer la durée
    
    If Duréee_Real_Box.Value <> "" Then
    Range("O" & lignesyst) = Duréee_Real_Box.Value
    End If
    
    ' supprimer en cours + responsable
    
    Range("U" & lignesyst).Clear
    Range("V" & lignesyst).Clear
    
    ' mise en forme de la ligne
    
    Range("U" & lignesyst & ":V" & lignesyst).Select
        Selection.RowHeight = 50
        With Selection
            .HorizontalAlignment = xlLeft
            .VerticalAlignment = xlCenter
            .WrapText = True
            .Orientation = 0
            .AddIndent = False
            .IndentLevel = 0
            .ShrinkToFit = False
            .ReadingOrder = xlContext
            .MergeCells = False
        End With
        With Selection.Font
            .Name = "Arial"
            .FontStyle = "Normal"
            .Size = 12
            .Strikethrough = False
            .Superscript = False
            .Subscript = False
            .OutlineFont = False
            .Shadow = False
            .Underline = xlUnderlineStyleNone
        End With
        Selection.Borders(xlDiagonalDown).LineStyle = xlNone
        Selection.Borders(xlDiagonalUp).LineStyle = xlNone
        With Selection.Borders(xlEdgeLeft)
            .LineStyle = xlContinuous
            .Weight = xlThin
            .ColorIndex = xlAutomatic
        End With
        With Selection.Borders(xlEdgeTop)
            .LineStyle = xlContinuous
            .Weight = xlThin
            .ColorIndex = xlAutomatic
        End With
        With Selection.Borders(xlEdgeBottom)
            .LineStyle = xlContinuous
            .Weight = xlThin
            .ColorIndex = xlAutomatic
        End With
        With Selection.Borders(xlEdgeRight)
            .LineStyle = xlContinuous
            .Weight = xlThin
            .ColorIndex = xlAutomatic
        End With
        With Selection.Borders(xlInsideVertical)
            .LineStyle = xlContinuous
            .Weight = xlThin
            .ColorIndex = xlAutomatic
        End With
    
    
    ActiveSheet.Protect DrawingObjects:=False, Contents:=True, Scenarios:= _
            False, AllowFiltering:=True, AllowUsingPivotTables:=True
    
    ' Mise à jour dans l'historique
    
    Range("A" & lignesyst & ":S" & lignesyst).Select
    Selection.Copy
    
    Sheets("HISTO.SYSTEMATIQUE").Select
    
    Sheets("HISTO.SYSTEMATIQUE").Unprotect Password:="remi"
    ActiveSheet.Unprotect Password:="remi"
    
    
    Dercell = Range("A65000").End(xlUp).Row + 1
    Range("A" & Dercell).Select
    
    ActiveSheet.Paste
    
    ' Donner l'auteur
    
    Dercell = Range("A65000").End(xlUp).Row
    Range("T" & Dercell) = Auteur_ComboBox
        
        ' Donner l'observation
    
    Dercell = Range("A65000").End(xlUp).Row
    Range("U" & Dercell) = Observ_Box
    
    ' Mettre en forme la ligne
    
    Range("A" & ActiveCell.Row & ":U" & ActiveCell.Row).Select
    Selection.RowHeight = 50
        With Selection
            .HorizontalAlignment = xlLeft
            .VerticalAlignment = xlCenter
            .WrapText = True
            .Orientation = 0
            .AddIndent = False
            .IndentLevel = 0
            .ShrinkToFit = False
            .ReadingOrder = xlContext
            .MergeCells = False
        End With
        With Selection.Font
            .Name = "Arial"
            .FontStyle = "Normal"
            .Size = 12
            .Strikethrough = False
            .Superscript = False
            .Subscript = False
            .OutlineFont = False
            .Shadow = False
            .Underline = xlUnderlineStyleNone
        End With
        Selection.Borders(xlDiagonalDown).LineStyle = xlNone
        Selection.Borders(xlDiagonalUp).LineStyle = xlNone
        With Selection.Borders(xlEdgeLeft)
            .LineStyle = xlContinuous
            .Weight = xlThin
            .ColorIndex = xlAutomatic
        End With
        With Selection.Borders(xlEdgeTop)
            .LineStyle = xlContinuous
            .Weight = xlThin
            .ColorIndex = xlAutomatic
        End With
        With Selection.Borders(xlEdgeBottom)
            .LineStyle = xlContinuous
            .Weight = xlThin
            .ColorIndex = xlAutomatic
        End With
        With Selection.Borders(xlEdgeRight)
            .LineStyle = xlContinuous
            .Weight = xlThin
            .ColorIndex = xlAutomatic
        End With
        With Selection.Borders(xlInsideVertical)
            .LineStyle = xlContinuous
            .Weight = xlThin
            .ColorIndex = xlAutomatic
        End With
    
    ActiveSheet.Protect DrawingObjects:=False, Contents:=True, Scenarios:= _
            False, AllowFiltering:=True, AllowUsingPivotTables:=True
    
    
    ' Retourner à la feuille systématique
    Sheets("SYSTEMATIQUE").Select
    ActiveSheet.Rows(ActiveCell.Row).EntireRow.Select
    
    ActiveSheet.Protect DrawingObjects:=False, Contents:=True, Scenarios:= _
            False, AllowFiltering:=True, AllowUsingPivotTables:=True
    
    MsgBox "La date à été mise à jour !", vbInformation, _
    "Systématique soldée !"
    
    'sauvegarde automatique
    ActiveWorkbook.Save
    End

    Je ne comprend pas pourquoi avant elle fonctionné très bien depuis j'ai changer les multiples .

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Selection.AutoFilter Field:=1
            Selection.AutoFilter Field:=2
              Selection.AutoFilter Field:=...
                    Selection.AutoFilter Field:=22
    par

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Columns("A:V").AutoFilter
    Est-il possible que ca vienne de là??

    Je suppose que mon code n'est pas assez "bien fait" pour fonctionner correctement.

    D'avance merci de prendre le temps de m'aider.

    Cordialement

  2. #2
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonsoir,
    et si soulageais un peu ton code, j'ai remplacé ton activepaste par cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("A" & dercell, "V" & dercell) = Sheets("SYSTEMATIQUE").Range("A" & lignesyst & ":S" & lignesyst).Select
    donc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Range("A" & lignesyst & ":S" & lignesyst).Select
    Selection.Copy
    devient inutile

    tu as plusieurs lignes de code inutiles

    j'espère ça fonctionnera comme ça

    bonne soirée
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    32
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 32
    Par défaut
    Bonsoir!

    Merci de me revenir en aide!

    J'ai essayé le ligne que vous m'avez donné mais celle - ci ne fonctionne pas.
    On m'indique erreur 1004 : impossible de lire la propriété select de la classe range

    J'ai essayé d'activé la feuille avec worksheet("HISTO.SYSTEMATIQUE")Activate mais sans succès.


    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
    ' Mise à jour dans l'historique
     
    Sheets("HISTO.SYSTEMATIQUE").Select
     
    Sheets("HISTO.SYSTEMATIQUE").Unprotect Password:="remi"
    ActiveSheet.Unprotect Password:="remi"
     
     
    Dercell = Range("A65000").End(xlUp).Row + 1
    Range("A" & Dercell).Select
     
    Range("A" & Dercell, "V" & Dercell) = Sheets("SYSTEMATIQUE").Range("A" & lignesyst & ":S" & lignesyst).Select
     
    ' Donner l'auteur
     
    Dercell = Range("A65000").End(xlUp).Row
    Range("T" & Dercell) = Auteur_ComboBox
     
        ' Donner l'observation
     
    Dercell = Range("A65000").End(xlUp).Row
    Range("U" & Dercell) = Observ_Box

    Encore merci d'avance

  4. #4
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    A quel endroit ce message ?, fait le code en pas à pas et vois ou ce ne va pas
    j'ai oublié d'enlevé le .select

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("A" & dercell, "V" & dercell) = Sheets("SYSTEMATIQUE").Range("A" & lignesyst & ":S" & lignesyst)
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  5. #5
    Expert éminent 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
    Par défaut
    N'oubliez pas le .value et les 2 ranges de même taille
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets("HISTO.SYSTEMATIQUE").Range("A" & dercell & ":S" & dercell).value = Sheets("SYSTEMATIQUE").Range("A" & lignesyst & ":S" & lignesyst).Value

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    32
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 32
    Par défaut
    Tout d'abords merci beaucoup de votre rapidité.
    Sans le select cela fonctionne, je l'ai remplacé par grâce à vous j'obtiens exactement je ce que je souhaite.7

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("A" & Dercell, "V" & Dercell) = Sheets("SYSTEMATIQUE").Range("A" & lignesyst & ":S" & lignesyst).Value
    Merci aussi pour la ligne dont je vais surement me resservir pour alléger mon code qui est assez conséquent.

    Un grand merci une fois de plus.

    Bonne soirée à vous.

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

Discussions similaires

  1. Probleme avec copy past
    Par tamtam64 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 26/05/2015, 23h22
  2. Erreur Couper/Coller ActiveSheet.Paste
    Par france38 dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 20/04/2011, 12h53
  3. [XL-2003] Plantage TCD Activesheet.Paste
    Par arnaud_verlaine dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 11/01/2011, 10h46
  4. [XL-2007] VBA Probleme avec ActiveSheet.Shapes
    Par vikingraver dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 09/06/2009, 18h06
  5. Activesheets.paste et les dates.
    Par bigboss60 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 21/11/2007, 10h55

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