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 :

Utilisation du presse-papier


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2008
    Messages : 611
    Points : 359
    Points
    359
    Par défaut Utilisation du presse-papier
    Je cherche à remplir une feuille d'un classeur à partir de l'agrégation de tableaux présents dans d'autres feuilles d'un autre classeur.

    Pour cela, je:

    - me positionne sur le classeur qui doit recevoir la totalité des tableaux,
    - j'efface toute la feuille
    - j'ouvre le classeur qui contient tous les tableaux à copier,
    - je me place sur la première feuille
    - je me place sur la cellule A1
    - je recopie l'ensemble du tableau (par un équivalent d'un CTRL + Maj + Fin)
    - je me place sur la feuille suivante et je fais copie ajout etc ...

    Mes questions:

    - je souhaiterai effacer le contenu du presse-papier avant de faire mes copiers (j'ai pourtant essayé pas mal de chose vu sur le NET)

    - je ne sais pas comment vider l'intégralité du presse-papier dans ma feuille cible.

    Merci d'avance.

  2. #2
    Expert éminent
    Avatar de Didier Gonard
    Homme Profil pro
    Formateur Office et développeur VBA en freelance
    Inscrit en
    Février 2008
    Messages
    2 805
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Formateur Office et développeur VBA en freelance

    Informations forums :
    Inscription : Février 2008
    Messages : 2 805
    Points : 6 696
    Points
    6 696
    Par défaut
    Bonjour,

    Si tu es sous 2000, il se peut que :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.CutCopyMode = False
    pour les versions suivantes avec l'apparition du volet office et de plusieurs couche de presse-papier, ça se complique notablement

    note :
    plutot que :
    (j'ai pourtant essayé pas mal de chose vu sur le NET)
    tu mettrais ce qui ne marche déjà pas, ça éviterait des réponses inutiles voir un "sans réponse"...

    cordialement,

    Didier
    Didier Gonard

    Dernier tutoriel :
    Le VBA qu'est ce que c'est ?
    Tutoriels : Voir la liste de mes tutoriels Excel & VBA et mon site pro sur ma Page DVP
    Cours et tutoriels pour apprendre Excel
    N'oubliez pas de mettre : ..quand c'est le cas !

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2008
    Messages : 611
    Points : 359
    Points
    359
    Par défaut
    La solution proposée ne vide pas le presse-papier.

    Puis-je utiliser ce morceau de code ajoutant une librairie sur Excel 2000 ?

    J'ai une erreur "Type de variable non définie" sur Dim oDataObject As DataObject

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub ClearClipboard()
    Dim oDataObject As DataObject
     
    Set oDataObject = New DataObject
    oDataObject.SetText ""
    oDataObject.PutInClipboard
     
    Set oDataObject = Nothing
    End Sub

  4. #4
    Membre expérimenté Avatar de laetitia
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    1 281
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 281
    Points : 1 512
    Points
    1 512
    Par défaut
    bonjour juju05 Didier le forum cette methode

    'Nécéssite d'activer la référence "Microsoft Forms 2.0 Object Library"
    'Dans l'editeur de macros:
    'Menu Outils
    'Références
    'Coche le ligne "Microsoft Forms 2.0 Object Library"
    'Clique sur OK pour valider

    autrement tu peus essaye

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Option Explicit
    Private Declare Function OpenClipboard Lib "user32" (ByVal hwnd As Long) As Long
    Private Declare Function CloseClipboard Lib "user32" () As Long
    Private Declare Function EmptyClipboard Lib "user32" () As Long
    Private Sub Commande0_Click()
        OpenClipboard 0
        EmptyClipboard
        CloseClipboard
    End Sub
    'ou encore simplement

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Sub es()
      On Error Resume Next
        Application.CommandBars("clipboard").Controls(4).Execute
    End Sub
    SALUTATIONS

  5. #5
    Membre averti
    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2008
    Messages : 611
    Points : 359
    Points
    359
    Par défaut
    Citation Envoyé par laetitia Voir le message
    bonjour juju05 Didier le forum cette methode

    'Nécéssite d'activer la référence "Microsoft Forms 2.0 Object Library"
    'Dans l'editeur de macros:
    'Menu Outils
    'Références
    'Coche le ligne "Microsoft Forms 2.0 Object Library"
    'Clique sur OK pour valider

    autrement tu peus essaye

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Option Explicit
    Private Declare Function OpenClipboard Lib "user32" (ByVal hwnd As Long) As Long
    Private Declare Function CloseClipboard Lib "user32" () As Long
    Private Declare Function EmptyClipboard Lib "user32" () As Long
    Private Sub Commande0_Click()
        OpenClipboard 0
        EmptyClipboard
        CloseClipboard
    End Sub
    'ou encore simplement

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Sub es()
      On Error Resume Next
        Application.CommandBars("clipboard").Controls(4).Execute
    End Sub
    - Je ne vois pas la librairie que tu cites.

    - Si je fais copier/coller de ta 2ème solution sous l'éditeur de macro et que je lance la procédure, il ne se passe rien.

    - la 3ème solution ne fonctionne pas si le presse-papier est vide(la méthode a échoué).

  6. #6
    Expert éminent
    Avatar de Didier Gonard
    Homme Profil pro
    Formateur Office et développeur VBA en freelance
    Inscrit en
    Février 2008
    Messages
    2 805
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Formateur Office et développeur VBA en freelance

    Informations forums :
    Inscription : Février 2008
    Messages : 2 805
    Points : 6 696
    Points
    6 696
    Par défaut
    bonjour,

    c'est depuis 2000 qu'Excel contient plusieurs presse-papiers, on en revient là :

    http://www.developpez.net/forums/d82...-excel-office/

    cordialement,

    Didier
    Didier Gonard

    Dernier tutoriel :
    Le VBA qu'est ce que c'est ?
    Tutoriels : Voir la liste de mes tutoriels Excel & VBA et mon site pro sur ma Page DVP
    Cours et tutoriels pour apprendre Excel
    N'oubliez pas de mettre : ..quand c'est le cas !

  7. #7
    Membre averti
    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2008
    Messages : 611
    Points : 359
    Points
    359
    Par défaut
    J'ai peut-être la solution sous les yeux. A quel moment le presse-papier est t-il vidé automatiquement ?

Discussions similaires

  1. Copier une image SANS utiliser le presse-papier
    Par MisterLo dans le forum Macros et VBA Excel
    Réponses: 19
    Dernier message: 18/11/2011, 16h36
  2. Utilisation du Presse-Papier
    Par arnolem dans le forum Téléchargez
    Réponses: 0
    Dernier message: 03/10/2011, 09h09
  3. Réponses: 4
    Dernier message: 18/05/2006, 11h07
  4. utiliser la presse papier du windows
    Par zidenne dans le forum Langage
    Réponses: 6
    Dernier message: 23/01/2006, 20h23
  5. pb d'utilisation du presse-papier
    Par olabo dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 10/02/2005, 13h06

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