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 :

Bug copier coller après évènement


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2020
    Messages : 15
    Par défaut Bug copier coller après évènement
    Bonjour,

    je n'arrive plus à copier coller dès que j'active l'évènement suivant.

    En gros, dès que je change de feuille, je n'ai plus le menu de collage. Et toutes mes macros de copy ne fonctionnent plus..

    Si quelqu'un à une idée ? je vous remercie,

    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
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    Private Sub appXls_SheetActivate(ByVal Sh As Object)
     
     
    Application.ScreenUpdating = False
    Application.Calculation = xlCalculationManual
     
     
    If Sh.Name = "acceuil" Then
     
    Dim derlign As Integer
    derlign = Sh.Previous.Range("A" & Rows.Count).End(xlUp).Row + 100
     
    'code client+ca
     
    Sh.Range("d12:d" & derlign).Value = Sh.Previous.Range("a2:a" & derlign).Value
     
    Sh.Range("E12:E" & derlign).Value = Sh.Previous.Range("X2:X" & derlign).Value
     
    'honos
     
    Sh.Range("f12:f" & derlign).Value = Sh.Previous.Range("s2:s" & derlign).Value
     
    'ir
     
    Sh.Range("g12:g" & derlign).Value = Sh.Previous.Range("l2:l" & derlign).Value
     
    'taux horaire
    Sh.Range("h12:h" & derlign).Value = Sh.Previous.Range("by2:by" & derlign).Value
     
     
     
     
    'actualisation feuille client
     
    Dim i As Integer
     
    For i = 1 To derlign + 2
     
    If Sh.Range("y1").Value = Sh.Previous.Cells(i, 1) Then
     
     
    Sh.Next.Range("d7") = Sh.Previous.Cells(i, 2)
     
    Sh.Next.Range("d8") = Sh.Previous.Cells(i, 3)
     
    Sh.Next.Range("d9") = Sh.Previous.Cells(i, 4)
     
    Sh.Next.Range("d10") = Sh.Previous.Cells(i, 5)
     
    Sh.Next.Range("d11") = Sh.Previous.Cells(i, 6)
     
    Sh.Next.Range("d12") = Sh.Previous.Cells(i, 22)
     
    Sh.Next.Range("d13") = Sh.Previous.Cells(i, 24)
     
    Sh.Next.Range("i7") = Sh.Previous.Cells(i, 7)
     
    Sh.Next.Range("i8") = Sh.Previous.Cells(i, 8)
     
    Sh.Next.Range("i9") = Sh.Previous.Cells(i, 10)
    Sh.Next.Range("i9").NumberFormat = "dd/mm/yyyy"
     
    Sh.Next.Range("i10") = Sh.Previous.Cells(i, 12)
     
    Sh.Next.Range("i11") = Sh.Previous.Cells(i, 68)
     
    Sh.Next.Range("i12") = Sh.Previous.Cells(i, 69)
     
    Sh.Next.Range("i13") = Sh.Previous.Cells(i, 70)
     
    Sh.Next.Range("a2") = "client depuis le " & Sh.Previous.Cells(i, 21)
    Sh.Next.Range("c2") = Sh.Previous.Cells(i, 67)
     
    Sh.Next.Range("f1") = Sh.Previous.Cells(i, 19) & " € "
    Sh.Next.Range("f1").NumberFormat = "0 $"
     
    Sh.Next.Range("i1") = Sh.Previous.Cells(i, 13)
    Sh.Next.Range("i1").NumberFormat = "0"
     
     
     
     
     
    End If
     
    Next i
    End If
     
     
     'actualisation feuille equipement
     
     
     
     
     
     
     
     
    For i = 1 To derlign
     
    If Sh.Range("y1").Value = Sh.Previous.Cells(i, 1) Then
     
     
     
    Sh.Next.Next.Range("e13") = Sh.Previous.Cells(i, 57)
    Sh.Next.Next.Range("e14") = Sh.Previous.Cells(i, 61)
    Sh.Next.Next.Range("e15") = Sh.Previous.Cells(i, 16)
    Sh.Next.Next.Range("e16") = Sh.Previous.Cells(i, 17)
    Sh.Next.Next.Range("e17") = Sh.Previous.Cells(i, 58)
    Sh.Next.Next.Range("e18") = Sh.Previous.Cells(i, 60)
    Sh.Next.Next.Range("h13") = Sh.Previous.Cells(i, 62)
    Sh.Next.Next.Range("h14") = Sh.Previous.Cells(i, 15)
    Sh.Next.Next.Range("h15") = Sh.Previous.Cells(i, 54)
    Sh.Next.Next.Range("h16") = Sh.Previous.Cells(i, 55)
    Sh.Next.Next.Range("h17") = Sh.Previous.Cells(i, 59)
    Sh.Next.Next.Range("k15") = Sh.Previous.Cells(i, 18)
    Sh.Next.Next.Range("k16") = Sh.Previous.Cells(i, 56)
    Sh.Next.Next.Range("k14") = Sh.Previous.Cells(i, 65)
    Sh.Next.Next.Range("k13") = Sh.Previous.Cells(i, 66)
    Sh.Next.Next.Range("f1") = Sh.Previous.Cells(i, 19) & " € "
    Sh.Next.Next.Range("f1").NumberFormat = "0 $"
    Sh.Next.Next.Range("h18") = Sh.Previous.Cells(i, 63)
    Sh.Next.Next.Range("h19") = Sh.Previous.Cells(i, 64)
     
    Sh.Next.Next.Range("a2") = "client depuis le " & Sh.Previous.Cells(i, 21)
     
    End If
     
    Next i
     
     
      'actualisation feuille mission
     
     
     
     
     
     
     
     
    For i = 1 To derlign
     
    If Sh.Range("y1").Value = Sh.Previous.Cells(i, 1) Then
     
    Sh.Next.Next.Next.Range("a2") = "client depuis le " & Sh.Previous.Cells(i, 21)
     
    Sh.Next.Next.Next.Range("f1") = Sh.Previous.Cells(i, 19)
    Sh.Next.Next.Next.Range("f1") = Sh.Previous.Cells(i, 19) & " € "
    Sh.Next.Next.Next.Range("f1").NumberFormat = "0 $"
     
    Sh.Next.Next.Next.Range("c12:h1000").ClearContents
     
     
    Sh.Next.Next.Next.Range("c12") = Sh.Previous.Previous.Cells(i, 2)
    Sh.Next.Next.Next.Range("c13") = Sh.Previous.Previous.Cells(i, 3)
    Sh.Next.Next.Next.Range("c14") = Sh.Previous.Previous.Cells(i, 4)
    Sh.Next.Next.Next.Range("c16") = Sh.Previous.Previous.Cells(i, 5)
    Sh.Next.Next.Next.Range("c15") = Sh.Previous.Previous.Cells(i, 6)
    Sh.Next.Next.Next.Range("c17") = Sh.Previous.Previous.Cells(i, 7)
    Sh.Next.Next.Next.Range("c18") = Sh.Previous.Previous.Cells(i, 8)
    Sh.Next.Next.Next.Range("c19") = Sh.Previous.Previous.Cells(i, 9)
    Sh.Next.Next.Next.Range("c20") = Sh.Previous.Previous.Cells(i, 10)
    Sh.Next.Next.Next.Range("c21") = Sh.Previous.Previous.Cells(i, 11)
    Sh.Next.Next.Next.Range("c22") = Sh.Previous.Previous.Cells(i, 12)
    Sh.Next.Next.Next.Range("c23") = Sh.Previous.Previous.Cells(i, 13)
    Sh.Next.Next.Next.Range("c24") = Sh.Previous.Previous.Cells(i, 14)
    Sh.Next.Next.Next.Range("c25") = Sh.Previous.Previous.Cells(i, 15)
    Sh.Next.Next.Next.Range("c26") = Sh.Previous.Previous.Cells(i, 16)
    Sh.Next.Next.Next.Range("c27") = Sh.Previous.Previous.Cells(i, 17)
     
    Sh.Next.Next.Next.Range("c28") = Sh.Previous.Previous.Cells(i, 18)
    Sh.Next.Next.Next.Range("c29") = Sh.Previous.Previous.Cells(i, 19)
     
     
    Sh.Next.Next.Next.Range("c30") = Sh.Previous.Previous.Cells(i, 20)
    Sh.Next.Next.Next.Range("c31") = Sh.Previous.Previous.Cells(i, 21)
    Sh.Next.Next.Next.Range("c32") = Sh.Previous.Previous.Cells(i, 22)
    Sh.Next.Next.Next.Range("c33") = Sh.Previous.Previous.Cells(i, 23)
    Sh.Next.Next.Next.Range("c34") = Sh.Previous.Previous.Cells(i, 24)
    Sh.Next.Next.Next.Range("c35") = Sh.Previous.Previous.Cells(i, 25)
     
    Sh.Next.Next.Next.Range("c37") = Sh.Previous.Previous.Cells(i, 27)
    Sh.Next.Next.Next.Range("c38") = Sh.Previous.Previous.Cells(i, 28)
    Sh.Next.Next.Next.Range("c39") = Sh.Previous.Previous.Cells(i, 29)
    Sh.Next.Next.Next.Range("c40") = Sh.Previous.Previous.Cells(i, 30)
    Sh.Next.Next.Next.Range("c41") = Sh.Previous.Previous.Cells(i, 31)
     
     
    Sh.Next.Next.Next.Range("c42") = Sh.Previous.Previous.Cells(i, 32)
    Sh.Next.Next.Next.Range("c43") = Sh.Previous.Previous.Cells(i, 33)
    Sh.Next.Next.Next.Range("c44") = Sh.Previous.Previous.Cells(i, 34)
     
     
    Sh.Next.Next.Next.Range("c45") = Sh.Previous.Previous.Cells(i, 35)
    Sh.Next.Next.Next.Range("c46") = Sh.Previous.Previous.Cells(i, 36)
    Sh.Next.Next.Next.Range("c47") = Sh.Previous.Previous.Cells(i, 37)
     
     
    Sh.Next.Next.Next.Range("c48") = Sh.Previous.Previous.Cells(i, 38)
    Sh.Next.Next.Next.Range("c49") = Sh.Previous.Previous.Cells(i, 39)
    Sh.Next.Next.Next.Range("c50") = Sh.Previous.Previous.Cells(i, 40)
    Sh.Next.Next.Next.Range("c51") = Sh.Previous.Previous.Cells(i, 41)
     
     
    Sh.Next.Next.Next.Range("c52") = Sh.Previous.Previous.Cells(i, 42)
    Sh.Next.Next.Next.Range("c53") = Sh.Previous.Previous.Cells(i, 43)
     
     
    Sh.Next.Next.Next.Range("c54") = Sh.Previous.Previous.Cells(i, 44)
     
     
    Sh.Next.Next.Next.Range("c55") = Sh.Previous.Previous.Cells(i, 45)
     
     
    Sh.Next.Next.Next.Range("c56") = Sh.Previous.Previous.Cells(i, 46)
     
    On Error Resume Next
     
     Sh.Next.Next.Next.Range("$C$11:$h$1000").AutoFilter Field:=1, Criteria1:="<>"
     
    End If
     
    Next i
     
     
     
     
       Application.ScreenUpdating = True
    Application.Calculation = xlCalculationAutomatic
     
    End Sub

  2. #2
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 184
    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 : 13 184
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    En gros, dés que je change de feuille, je n'ai plus le menu de collage. Et toutes mes macros de copy ne fonctionnent plus
    Qu'entendez-vous par menu de collage ?
    Avez-vous un message d'erreur ?

    Petite remarque : On a beau vous expliquer qu'il est préférable de travailler autrement, vous persistez dans les mauvaises pratiques.
    Utiliser la position d'une feuille pour lire et écrire est extrêmement dangereux. La feuille 1 est celle qui se trouve à gauche dans le classeur. Il suffirait donc que l'on insère une feuille ou que l'on en supprime une juste à gauche de votre feuille nommée Accueil pour que les Previous.Previous, etc. ne soit plus à la bonne place
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  3. #3
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2020
    Messages : 15
    Par défaut
    J’ai bien pris note des conseils. Cependant, aucune utilité pour moi dans la mesure où l’utilisateur ne pourra et ne devra pas modifier la structure du classeur et la position des colonnes. L’ensemble des macros fonctionnent avec des positions relatives. C’est clairement une faiblesse mais elle est explicitement comprise par les utilisateurs. D’ailleurs c’est un outil davantage de visualisation de données. Les seules modifications possibles sont via des userform et un import de logiciels tiers.
    Par ailleurs, je ne cherche pas ici des critiques qui n’apportent pas de valeur et ne servent qu’à parfaire une méthodologie comme avec un élève mais plutôt une aide sur des sujets précis comme indiqué dans le titre.

  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
    13 184
    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 : 13 184
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Ne vous inquiétez pas, je ne répondrai plus à vos questions.
    Juste une dernière pour la route puisque je suis là. En ligne 217 de votre code publié, vous avez une instruction On Error Resume Next que personnellement j'enlèverais parce-que comme elle se trouve dans la boucle, c'est plutôt un "cache misère". S'il y a une erreur, elle ne vous sera pas signalée
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  5. #5
    Expert éminent

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 584
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Conseil, Formation, Développement - Indépendant

    Informations forums :
    Inscription : Février 2010
    Messages : 8 584
    Par défaut
    Bonjour à tous

    Comme disait un de mes collègues commentant le code pourri ne respectant aucune méthodologie de notre chef "heureusement on ne programme pas le pilotage automatique d'avions sinon on aurait pas mal de morts sur la conscience.
    Là les crashs successifs ne font qu'agacer le client..."

    Cela a été vrai jusqu"au crash de la boîte elle-même...

  6. #6
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2020
    Messages : 15
    Par défaut
    «*Le seul critère d’un savoir véritable est son efficacité*» Bruce lee

  7. #7
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 184
    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 : 13 184
    Billets dans le blog
    53
    Par défaut
    Bonsoir,
    «*Le seul critère d’un savoir véritable est son efficacité*» Bruce lee
    Puisque l'on parle d'efficacité et que vous voulez absolument utiliser des positions relatives par rapport à la variable objet sh
    Utilisez plutôt la propriété Index qui indique sa position dans le classeur ce qui vous évitera l'emploi des propriétés Previous et Next parce-que la lecture de cette ligne Sh.Next.Next.Next.Range("c12") = Sh.Previous.Previous.Cells(i, 2) est pour le moins indigeste et tant qu'à faire sh étant un objet non explicite et donc ne permettant pas l'usage de l'Intellisense, je définirais deux variables objets de type Worksheet l'une pour la feuille source et l'autre pour la cible.

    Exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Private Sub Workbook_SheetActivate(ByVal Sh As Object)
      Dim shtSource As Worksheet
      Dim shtTarget As Worksheet
      With Sh
        If .Name = "Accueil" Then
           Set shtSource = Worksheets(Sh.Index + 2) ' sh.Next.Next
           Set shtTarget = Worksheets(Sh.Index - 3) ' sh.Previous.Previous.Previous
           Debug.Print shtTarget.Name & " - " & shtSource.Name
        End If
      End With
      Set shtSource = Nothing: Set shtTarget = Nothing
    End Sub
    Pour faciliter la maintenance je créerais des procédures externes à la procédure événementielle appXls_SheetActivate pour l'écriture dans les cellules comme l'a d'ailleurs suggéré deedolith, que je salue au passage, dans sa réponse Fil #8 de l'autre discussion
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  8. #8
    Expert confirmé
    Avatar de jurassic pork
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Décembre 2008
    Messages
    4 252
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2008
    Messages : 4 252
    Par défaut
    Hello,
    Citation Envoyé par benjamin66666 Voir le message
    En gros, dès que je change de feuille, je n'ai plus le menu de collage. Et toutes mes macros de copy ne fonctionnent plus..
    En fait ce n'est pas le menu du collage qui n'est plus là (ce qui correspond en fait à la partie collage du menu contextuel de la feuille qui est grisée) mais c'est le presse-papier qui est effacé donc on n'a plus rien à coller. Ceux sont les instructions qui changent la valeur de Application.Calculation qui effacent le presse-papier alors soit on n'utilise pas ces instructions, soit on s'assure qu'il n'y a rien dans le presse-papier avant de les utiliser ou soit on les utilise avant ou après le copier coller.
    Ami calmant, J.P

  9. #9
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2020
    Messages : 15
    Par défaut
    salut,

    non, le presse papier n'est pas vidé, mais la valeur est désélectionnée.

    Le soucis, c'est que l'évènement s'active dés qu'une feuille est activé.

    Donc quoi que je fasse, j'ai ce bug..

    je ne comprend pas pourquoi;

  10. #10
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2020
    Messages : 15
    Par défaut
    c'est bon,

    j'ai trouvé le bug:

    je pensais que cela venait de la macro sheetactivate, mais en fait cela venait d'une autre macro beforerightclick!!

    enfin..

    Merci à tous,

  11. #11
    Expert confirmé
    Avatar de jurassic pork
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Décembre 2008
    Messages
    4 252
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2008
    Messages : 4 252
    Par défaut
    Citation Envoyé par benjamin66666 Voir le message
    non, le presse papier n'est pas vidé, mais la valeur est désélectionnée.
    Ab bon ? avec Quelle version d'Excel ?
    En Excel 2016 si je mets cette macro pour le classeur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Private Sub Workbook_SheetActivate(ByVal Sh As Object)
    Application.Calculation = xlCalculationManual
    Application.Calculation = xlCalculationAutomatic
    End Sub
    si je copie une cellule et que je change de feuille , je ne peux pas coller, il n'y a plus rien à coller ( dans le bloc note non plus ce qui prouve que c'est le presse-papier qui est vidé).

  12. #12
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2020
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2020
    Messages : 15
    Par défaut
    eh oui, tu as raison.
    J'ai cru que cela fonctionnait, mais en fait non.

    du coup, j'ai tout simplement supprimé la macro évènementielle sheetactivate que j'ai remplacé en partie par un module standard que l'utilisateur active via un bouton.

    Les autres mises à jours seront faites grâce à un beforedoubleclick qui ne fait pas bugger le copier/coller.

    l'utilisateur accède à un tableau de bord avec son portefeuille client en cliquant sur un bouton dans la barre d'outils : cela met à jour les données de l'onglet acceuil (module)
    puis, lorsqu'il double click sur le code d'un client, cela met à jour les données des onglets clients, équipements, et missions selon ce client particulier (évènement)

    En fait, j'aurais du y penser plus tôt. En plus, c'est moins gourmand, plus rapide et plus logique.

    Le sheetactivate est donc à éviter il me semble.

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

Discussions similaires

  1. Macro copier coller après ouverture d'adresses multiples
    Par cl3m_ dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 27/09/2016, 10h31
  2. [XL-2013] Aide Vba copier coller sous condition
    Par d.deneys dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 22/08/2013, 12h34
  3. [XL-2007] aide macro copier coller
    Par young 25 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 24/03/2012, 17h37
  4. [XL-2007] Problème de copier/coller aprés ajout d'une macro.
    Par crevette06220 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 06/08/2011, 23h29
  5. aide pour copier/coller et pour trier
    Par chamoxx dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 21/07/2008, 22h27

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