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 :

[VBA] Exporter des graphiques et des tableaux d'Excel vers Powerpoint en conservant la mise en forme source [XL-2013]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2016
    Messages : 16
    Par défaut [VBA] Exporter des graphiques et des tableaux d'Excel vers Powerpoint en conservant la mise en forme source
    Bonjour à Tous,

    Je suis un débutant dans l'embarras...J'ai parcouru plusieurs Forum, ça fait 24 heures que je bataille sur ce truc.
    Pour mon stage je dois automatiser un tableau de bord avec des graphiques et des tableaux.

    Premièrement j'ai une classe pour exporter les graphiques, puis une classe pour exporter les tableaux. Je n'arrive pas à fusionner les deux classes par manque
    de savoir. j'aimerai créer un bouton qui exécute les 2 classes: Sub GraphExcel_vers_PowerPoint() et
    Sub TableauexportPPT()

    Deuxièmement, lorsque l'export se fait sur powerpoint. Je ne veux surtout pas que le graphique soit en tant qu'image. Parfois ça fonctionne, le copier coller se fait en gardant la mise en forme de type excel et parfois c'est une image.

    Mon code n'est pas du tout optimiser mais j'essaye de faire de mon mieux :
    MERCI à ceux qui veulent m'aider et pour votre pédagogie.


    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
     
    Sub GraphExcel_vers_PowerPoint()
                    Dim sPPTFileName As String
                    Dim ppApp As PowerPoint.Application
                    Dim ppPres As PowerPoint.Presentation
                    Dim cht As Excel.ChartObject
     
     
     
     
                        'Sélectionner le fichier PowerPoint à ouvrir
                           sPPTFileName = GetFileName
     
    'Ouvrir PowerPoint
                       Set ppApp = CreateObject("PowerPoint.Application")
                       ppApp.Visible = msoTrue
                       Set ppPres = ppApp.Presentations.Open(sPPTFileName)
                       ppApp.ActiveWindow.ViewType = ppViewSlide
     
                            ' >>>>>>>>
                               'Appel de la fonction pour copier graphique dans PowerPoint
                               'Graphique no1
     
                            Set cht = ThisWorkbook.Sheets("SUIVI DES COMMANDES").ChartObjects("Graphique 1")
                            Call ChartsToPPT(ppPres, 2, cht, 130, 225, 465, 275)
     
                            'Set cht = ThisWorkbook.Sheets("SUIVI DES COMMANDES").
                            'Call ChartsToPPT(ppPres, 2, cht, 130, 405, 465, 150)
     
     
     
                            Set cht = ThisWorkbook.Sheets("SOCLE FIXE").ChartObjects("Graphique 1")
                            Call ChartsToPPT(ppPres, 2, cht, 335, 34, 170, 170) 'SOCLE PLACE
     
     
                            Set cht = ThisWorkbook.Sheets("SUIVI DES LIVRAISONS").ChartObjects("Graphique 1")
                            Call ChartsToPPT(ppPres, 3, cht, 130, 225, 465, 275)
     
                            Set cht = ThisWorkbook.Sheets("SUIVI DES LIVRAISONS").ChartObjects("Graphique 2")
                            Call ChartsToPPT(ppPres, 3, cht, 334, 36, 169, 159)
     
                            Set cht = ThisWorkbook.Sheets("SUIVI DES RECEPTIONS").ChartObjects("Graphique 1")
                            Call ChartsToPPT(ppPres, 4, cht, 130, 225, 465, 275)
     
                            Set cht = ThisWorkbook.Sheets("SUIVI DES VALIDATIONS").ChartObjects("Graphique 2")
                            Call ChartsToPPT(ppPres, 5, cht, 130, 225, 465, 275)
     
                            Set cht = ThisWorkbook.Sheets("SUIVI DES REFUS").ChartObjects("Graphique 1")
                            Call ChartsToPPT(ppPres, 6, cht, 130, 225, 465, 275)
     
                            Set cht = ThisWorkbook.Sheets("SUIVI DES RETARDS").ChartObjects("Graphique 1")
                            Call ChartsToPPT(ppPres, 7, cht, 130, 225, 465, 275)
     
     
     
     
     
     
     
                                Set cht = Nothing
                                Set ppPres = Nothing
                                Set ppApp = Nothing
     
    End Sub
     
     
     'Code pour copier le graphique spécifié dans la présentation
    Sub ChartsToPPT(oPPT As PowerPoint.Presentation, iSlideNo As Integer, _
                    cht As ChartObject, iTop As Integer, iLeft As Integer, iWidth As Integer, iHeight As Integer)
     
                       Dim ppSlide As PowerPoint.Slide
                       Dim pSh As PowerPoint.Shape
       'Choisir la diapositive
                       Set ppSlide = oPPT.Slides(iSlideNo)
     
                       cht.Copy
     
                       With ppSlide
                          .Shapes.PasteSpecial 'ppPasteDefault
                          'Paste:=xlPasteAllUsingSourceTheme, Operation:=xlNone _
    ', SkipBlanks:=False, Transpose:=False
                          Set pSh = .Shapes(.Shapes.Count)  '.Select  'Select the last shape
                       End With
     
       'Position et dimensions
                       With pSh
                          .Top = iTop
                          .Left = iLeft
                          .Width = iWidth
                          .Height = iHeight
                       End With
     
    End Sub
     
    Function GetFileName() As String
       Dim sFileName As Variant
       Dim sFileFilter As String, sTitle As String
     
       'sFileFilter:="Excel Files (*.xls), *.xls", Title:="Please select a file"
       sFileFilter = "PowerPoint Files (*.ppt*), *.ppt*"
       sTitle = "Please select a file"
       sFileName = Application.GetOpenFilename(sFileFilter, , sTitle)
       If sFileName <> False Then
          GetFileName = sFileName
     
       End If
    End Function
     
     
     
    Sub TableauexportPPT()
       'nécessite d'activer la référence Microsoft Powerpoint Object Library
        Dim PPT As PowerPoint.Application
        Dim PptDoc As PowerPoint.Presentation
        Dim NbShpe As Byte
     
     
       sPPTFileName = GetFileName
        Set PPT = CreateObject("Powerpoint.Application")
        PPT.Visible = True 'l'application sera visible
        Set PptDoc = PPT.Presentations.Open(sPPTFileName)
     
     
        'premier tableau
     
            ThisWorkbook.Worksheets("SUIVI DES COMMANDES").Range("C33:O38").Copy
     
            PptDoc.Slides(2).Shapes.PasteSpecial ppPasteDefault 'ppPasteEnhancedMetafile
     
            NbShpe = PptDoc.Slides(2).Shapes.Count
     
            With PptDoc.Slides(2).Shapes(NbShpe)
                '.Name = "NomForme"
                .Left = 224
                .Top = 290
                .Height = 77
                .Width = 480
     
            End With
     
     
     
                ThisWorkbook.Worksheets("SUIVI DES LIVRAISONS").Range("C41:O46").Copy
     
            PptDoc.Slides(3).Shapes.PasteSpecial ppPasteDefault 'ppPasteEnhancedMetafile
     
            NbShpe = PptDoc.Slides(3).Shapes.Count
     
        '2 eme tableau
            With PptDoc.Slides(3).Shapes(NbShpe)
                '.Name = "NomForme"
                .Left = 224
                .Top = 290
                .Height = 77
                .Width = 480
     
            End With
     
     
                    ThisWorkbook.Worksheets("SUIVI DES RECEPTIONS").Range("C41:O46").Copy
     
            PptDoc.Slides(4).Shapes.PasteSpecial ppPasteDefault 'ppPasteEnhancedMetafile
     
            NbShpe = PptDoc.Slides(4).Shapes.Count
     
            With PptDoc.Slides(4).Shapes(NbShpe)
                '.Name = "NomForme"
                .Left = 224
                .Top = 290
                .Height = 77
                .Width = 480
     
            End With
     
     
                ThisWorkbook.Worksheets("SUIVI DES VALIDATIONS").Range("C41:O46").Copy
     
            PptDoc.Slides(5).Shapes.PasteSpecial ppPasteDefault 'ppPasteEnhancedMetafile
     
            NbShpe = PptDoc.Slides(5).Shapes.Count
     
            With PptDoc.Slides(5).Shapes(NbShpe)
                '.Name = "NomForme"
                .Left = 224
                .Top = 290
                .Height = 77
                .Width = 480
     
            End With
     
     
               ThisWorkbook.Worksheets("SUIVI DES REFUS").Range("C41:O46").Copy
     
            PptDoc.Slides(6).Shapes.PasteSpecial ppPasteDefault 'ppPasteEnhancedMetafile
     
            NbShpe = PptDoc.Slides(6).Shapes.Count
     
            With PptDoc.Slides(6).Shapes(NbShpe)
                '.Name = "NomForme"
                .Left = 224
                .Top = 290
                .Height = 77
                .Width = 480
     
            End With
     
                ThisWorkbook.Worksheets("SUIVI DES RETARDS").Range("C41:O46").Copy
     
            PptDoc.Slides(7).Shapes.PasteSpecial ppPasteDefault 'ppPasteEnhancedMetafile
     
            NbShpe = PptDoc.Slides(7).Shapes.Count
     
            With PptDoc.Slides(7).Shapes(NbShpe)
                '.Name = "NomForme"
                .Left = 224
                .Top = 290
                .Height = 77
                .Width = 480
     
            End With
     
     
     
        'PptDoc.Save 'sauvegarder les modifications
        'PptDoc.Close 'fermer le document ppt
        'PPT.Quit 'fermer l'application powerPoint
     
    End Sub


    Cordialement

    Rabik33

  2. #2
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut
    Bonjour,
    J'ai tellement galéré sur ce sujet que maintenant je vais certainement pouvoir t'aider.

    Pour cela, envoie en PJ, ton fichier Excel et également ton PPT, tel que tu voudrais qu'il apparaisse.
    Met également le chemin complet où se trouve ton PPT afin qu'Excel puisse l'ouvrir.

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2016
    Messages : 16
    Par défaut PJ
    Ah merci beaucoup pour ton aide:
    Voici la PJ du fichier: INDEX_TDB.xlsm
    La feuille "paramétrage" contient les 2 boutons pour l'export.
    L'export se fait dans un fichier PPT quelque-conque il suffit qu'ils contiennent plus de 6 diapo.
    Pas besoin de spécifier l'emplacement du PPT, j'ai créer une fonction pour ouvrir une boite de dialogue.


    Ps je n'arrive pas à mettre en PJ le fichier PPT.

    Cordialement

    Rabik33

  4. #4
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut
    Ps je n'arrive pas à mettre en PJ le fichier PPT.
    Essaye en MP, peut etre que ça marchera.

  5. #5
    Community Manager

    Avatar de Malick
    Homme Profil pro
    Community Manager
    Inscrit en
    Juillet 2012
    Messages
    9 308
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Community Manager
    Secteur : Conseil

    Informations forums :
    Inscription : Juillet 2012
    Messages : 9 308
    Billets dans le blog
    15
    Par défaut


    Citation Envoyé par RabiK33 Voir le message
    Ps je n'arrive pas à mettre en PJ le fichier PPT.
    Vous pouvez le zipper et essayer à nouveau de le joindre.
    La taille maximale est de 2 Mo

    Cordialement,
    Malick
    Vous avez envie de contribuer au sein du Club Developpez.com ? Contactez-nous maintenant !
    Vous êtes passionné, vous souhaitez partager vos connaissances en informatique, vous souhaitez faire partie de la rédaction.
    Il suffit de vous porter volontaire et de nous faire part de vos envies de contributions :
    Rédaction d'articles/cours/tutoriels, Traduction, Contribution dans la FAQ, Rédaction de news, interviews et témoignages, Organisation de défis, de débats et de sondages, Relecture technique, Modération, Correction orthographique, etc..
    Vous avez d'autres propositions de contributions à nous faire ? Vous souhaitez en savoir davantage ? N'hésitez pas à nous approcher.

  6. #6
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2016
    Messages : 16
    Par défaut
    Voici le Fichier powerpoint. Il est basique mais vous permettra de mieux comprendre
    new2.zip

    Il suffit de lancer les macros et vous verrez le résultat.

    Cordialement.

    Rabik33

  7. #7
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut
    est ce que 7 diapo te convient ?
    sinon il me faut ton PPT car je veux voir ou tu desires placer tes tableaux et tes graphes et surtout a quelles dimensions.
    Je commence a bosser dessus demain et te rendrais ton fichier Dimanche ou au plus tard Lundi.
    Dans l'attente de ton PPT

  8. #8
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut
    Salut,
    Ci joint le PPTM et XLS.
    Modifie dans la macro le chemin d'accès au PPTM (PPT supportant les macros)
    J'ai modifier ton XLS en créant une nlle feuille "SUIVI RESTE A LIVRER" car dans l'onglet "SUIVI DES COMMANDES", tu avais deux graphes portant le meme nom et ça créé un bug.
    En esperant que cela te convienne.

    N'oublies pas de cliquer sur pour le travail réalisé et sur pour clôturer ton post si nécessaire.
    Fichiers attachés Fichiers attachés
    • Type de fichier : rar TdB.rar (95,0 Ko, 368 affichages)

  9. #9
    Membre émérite
    Homme Profil pro
    Directeur
    Inscrit en
    Avril 2003
    Messages
    724
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur

    Informations forums :
    Inscription : Avril 2003
    Messages : 724
    Par défaut
    Merci à graphikris, je crois que je vais aussi profiter de son code.

  10. #10
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut
    Citation Envoyé par Philippe PONS Voir le message
    Merci à graphikris, je crois que je vais aussi profiter de son code.
    N'oublies pas de cliquer sur pour le travail réalisé

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

Discussions similaires

  1. [PPT-2013] Conserver la mise en forme source des présentations en VBA
    Par fidecourt dans le forum VBA PowerPoint
    Réponses: 0
    Dernier message: 13/03/2013, 11h17
  2. [PPT-2007] Importe Graphes/tableaux d'Excel vers PowerPoint
    Par gabi75 dans le forum VBA PowerPoint
    Réponses: 8
    Dernier message: 01/06/2010, 15h35
  3. Dessiner des graphiques à partir des données d'une BD MySQL
    Par condor_01 dans le forum Général Java
    Réponses: 6
    Dernier message: 24/04/2008, 09h35
  4. [VBA]Export de graphiques vers Word
    Par Herman dans le forum VBA Access
    Réponses: 2
    Dernier message: 18/04/2007, 09h51
  5. Réponses: 4
    Dernier message: 30/05/2006, 17h21

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