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

Access Discussion :

[VBA] Ecrire "Copier/Coller"


Sujet :

Access

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 41
    Points : 24
    Points
    24
    Par défaut [VBA] Ecrire "Copier/Coller"
    Bonjour,

    Dans le cadre de l'export vers excel d'un formulaire complaxe, je n'ai pas trouvé de solution qui marche.

    Pourtant "à la main j'arrive tres bien à faire ce que je veux".

    Je fais:
    - "Edition / selectionner tout les enregistrements"
    - Copier
    - Je selectionne ma feuille excel
    - coller

    y a t'il un moyen d'ecrir en code ces trois lignes?

    (sachant que "Output to" ne convient pas car il crée forcement un nouveau fichier) et que "TransferSpreadsheet"; "OpenRecordset" et "CopyFromRecordset" ne marchent pas car exporte des table ou des requete mais pas le contenu d'un formulaire.


    Seule le bon vieux copier-coller à l'aire de marcher mais je ne sais pas comment l'automatiser ....

    (sinon je vais en etre reduit a essayer:


    Merci!

    Guillaume

  2. #2
    Membre émérite
    Avatar de DelphiManiac
    Homme Profil pro
    Homme à tout faire
    Inscrit en
    Mars 2002
    Messages
    1 147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Homme à tout faire
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 147
    Points : 2 533
    Points
    2 533
    Par défaut
    En partant du principe que le formulaire est en affiche continu, donc que l'on peut sélectionner tout les enregistrements.

    Poser un bouton sur le formulaire et sur l'évènement click, coller le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    Private Sub Commande6_Click()
      Dim e As Excel.Application
      Dim w As Excel.Workbook
     
      DoCmd.RunCommand acCmdSelectAllRecords
      DoCmd.RunCommand acCmdCopy
      Set e = New Excel.Application
      Set w = e.Workbooks.Add
     
      e.Visible = True
      e.ActiveSheet.Paste
    End Sub
    Il faut auparavant ajouter la référence à la bilbiothèque excel. Dans la fenetre de code, ouvrir le menu outils/références, rechercher la ligne "microsoft excel xx.x object library"

    Le code est a paufiner bien sur, mais il fait a priori le minimum nécessaire demandé.
    Si ce message vous a semblé utile, il est possible qu'il soit utile à d'autres personnes. Pensez au . Et n'oubliez pas le le moment venu !

    On n'a pas à choisir si l'on est pour ou contre la décroissance, elle est inéluctable, elle arrivera qu'on le veuille ou non.

  3. #3
    Membre habitué
    Inscrit en
    Juillet 2002
    Messages
    150
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 150
    Points : 169
    Points
    169
    Par défaut
    Salut,

    Les données de ton formulaire viennent d'où ? d'une table, d'une requête ?

    Les informations affichées dans le formulaire sont bien stockées quelque part et il est bien possible de les extraire selon certains critères ?

  4. #4
    Membre émérite
    Avatar de DelphiManiac
    Homme Profil pro
    Homme à tout faire
    Inscrit en
    Mars 2002
    Messages
    1 147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Homme à tout faire
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 147
    Points : 2 533
    Points
    2 533
    Par défaut
    Je suis parti du principe que les données provenaient d'une table ou d'une requete, peu importe, et étaient affichées dans un formulaire en mode continu.
    Si ce message vous a semblé utile, il est possible qu'il soit utile à d'autres personnes. Pensez au . Et n'oubliez pas le le moment venu !

    On n'a pas à choisir si l'on est pour ou contre la décroissance, elle est inéluctable, elle arrivera qu'on le veuille ou non.

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 41
    Points : 24
    Points
    24
    Par défaut
    Youpi!!

    CA marche!

    Merci!

  6. #6
    Membre émérite
    Avatar de DelphiManiac
    Homme Profil pro
    Homme à tout faire
    Inscrit en
    Mars 2002
    Messages
    1 147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Homme à tout faire
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 147
    Points : 2 533
    Points
    2 533
    Par défaut
    Ca fait toujours plaisir quand ca marche
    Si ce message vous a semblé utile, il est possible qu'il soit utile à d'autres personnes. Pensez au . Et n'oubliez pas le le moment venu !

    On n'a pas à choisir si l'on est pour ou contre la décroissance, elle est inéluctable, elle arrivera qu'on le veuille ou non.

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 41
    Points : 24
    Points
    24
    Par défaut
    Maintenant, plus difficile...


    J'arrive bien à copier le formulaire principal,

    J'aimerai faire la meme chose avec les données du sous formulaire;

    J'ai mis une instruction:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Me.P_SUB_BOOKING.SetFocus
    pour selectionner le sous formulaire, mais du coup lorsque je lui demande de faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DoCmd.RunCommand acCmdSelectAllRecords
    il me met un message d'erreure "la commande ou l'action selectionner tous les enregistrement n'est pas disponible pour l'instant"

    J'ai essayer de mettre le focus sur n champ interne du sous formulaire, mais il ne comprend pas...

  8. #8
    Membre émérite
    Avatar de DelphiManiac
    Homme Profil pro
    Homme à tout faire
    Inscrit en
    Mars 2002
    Messages
    1 147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Homme à tout faire
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 147
    Points : 2 533
    Points
    2 533
    Par défaut
    Ce message d'erreur est lié au fait que le sous formulaire n'est pas en mode continu ou en mode feuille de donénes, mais en mode "formulaire unique", donc tout les enregistrements ne peuvent etre sélectionnés et copiés.
    Si ce message vous a semblé utile, il est possible qu'il soit utile à d'autres personnes. Pensez au . Et n'oubliez pas le le moment venu !

    On n'a pas à choisir si l'on est pour ou contre la décroissance, elle est inéluctable, elle arrivera qu'on le veuille ou non.

  9. #9
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 41
    Points : 24
    Points
    24
    Par défaut
    bas non...

    aussi bien mon formulaire principale que mes sous formulaires sont en mode continu (et les sous formulaires contiennet parfois plusieur dizaines de lignes)

    par contre les sous formulaires sont sur des onglets.

    J'ai l'impression que c'est un probleme de focus, ou de truc comme ca...

Discussions similaires

  1. [VBA] Pb avec Copier/coller d'une feuille Excel
    Par sebastien_oasis dans le forum Excel
    Réponses: 3
    Dernier message: 14/12/2007, 11h08
  2. Réponses: 1
    Dernier message: 19/12/2006, 16h12
  3. [VBA-E]échec copier-coller entre 2classeurs
    Par touche_a_tout dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 06/12/2006, 23h22
  4. VBA-E: Pb copier-coller entre Excel et .csv
    Par tiger118 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 14/06/2006, 11h08

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