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 :

Création d'un tableau croisé dynamique [XL-2016]


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé
    Homme Profil pro
    Chef de projet Informatique
    Inscrit en
    Mai 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Chef de projet Informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2013
    Messages : 72
    Par défaut Création d'un tableau croisé dynamique
    Bonjour

    j'essaye de créer un TCD avec VBA. J'en enregistré une macro en créant depuis Excel. Puis j'ai commmencé à modifier des chaines pour les remplacer par des variables pour plus de souplesse. Quand j'essaye d'exécuter la création du TCD en seule instrcution, j'ai une erreur. Alors j'ai scindé en deux: creation du Pivotcache puis création du PivotTable. et c'est à l'appel pour la creation de PivotTable que j'ai l'erreur. Voici le bout de code
    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
    '
    ' CreationTCD_2 Macro
    ' Enregistrement creation TCD
    '
    
    '
        Dim objPivotCache As PivotCache
        Dim shSourceName As String
        Dim shDestName As String
        
        
        Sheets(getTCDdestSheet).Select
        Range("A1").Select
        shSourceName = getSourceTCDData & "!R1C1:R181C27"
        shDestName = getTCDdestSheet & "!R1C1"
        
        Set objPivotCache = ActiveWorkbook.PivotCaches.Create(SourceType:=xlDatabase, SourceData:= _
            shSourceName, Version:=6)
            objPivotCache.CreatePivotTable TableDestination _
            :=shDestName, TableName:="PivotTable1", ReadData:=False, DefaultVersion:=6
            
        'ActiveWorkbook.PivotCaches.Create(SourceType:=xlDatabase, SourceData:= _
         '   shSourceName, Version:=6).CreatePivotTable TableDestination _
          '  :=shDestName, TableName:="PivotTable1", DefaultVersion _
           ' :=6
    J'ai mis en rouge l'appel qui semble être la cause de l'erreur. les fonctions "getSourceTCDData et getTCDdestSheet" retournent respectivement les noms des feuilles sources des données en entrée et le nom de la feuille où sera mis le TCD. En pièce jointe un screenshot de l'appel et l'erreur.
    Merci pour vos conseils.
    Clem 256
    Images attachées Images attachées  

  2. #2

  3. #3
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Salut.

    Je ne connais pas le but de ta démarche, mais j'ai rarement eu à créer des tcd par macros.


    Peux-tu nous en dire plus sur la finalité de ta demande? Habituellement, on crée le TCD manuellement, et on met éventuellement les données à jour par macros. Normalement avec un 2016, ça demande une seule ligne de programmation car on appuie le TCD sur un tableau de données.
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  4. #4
    Invité
    Invité(e)
    Par défaut
    Bonjour Pierre,
    Je suis d'accord avec toi; un tdc qui prend en compte la colonne A:XX affichera le résultat et ce quelque soit le nombre de lignes!

    Mais vue le nombre demande lié a la construction dynamique de tdc j'ai mis en place une boîte à outils pour le permettre.

    Personnellement je préfère utiliser un Xltm; je ne gère jamais le création de tdc par macro!

  5. #5
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Bonjour Robert,

    J'apprécie beaucoup ton outil qui peut effectivement simplifier la création du tcd. Mais je trouve que dans de nombreux cas, travailler sur un modèle est bien plus simple que de se lancer dans la construction d'un tcd. A priori, créer un tcd par macro n'est pas très compliqué, mais souvent, cette construction par vba s'appuie sur une structure de classeur qui n'est pas tiptop et sur des connaissances VBA mal maîtrisées.

    Bonne journée
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  6. #6
    Membre confirmé
    Homme Profil pro
    Chef de projet Informatique
    Inscrit en
    Mai 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Chef de projet Informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2013
    Messages : 72
    Par défaut
    Citation Envoyé par Pierre Fauconnier Voir le message
    Salut.

    Je ne connais pas le but de ta démarche, mais j'ai rarement eu à créer des tcd par macros.


    Peux-tu nous en dire plus sur la finalité de ta demande? Habituellement, on crée le TCD manuellement, et on met éventuellement les données à jour par macros. Normalement avec un 2016, ça demande une seule ligne de programmation car on appuie le TCD sur un tableau de données.
    Bonsoir Pierre

    Merci pour ton retour. Je ne sais pas si j'ai choisi la bonne approche, mais mon objectif est simple. Je dois produire un rapport deux à trois fois par semaine à partir d'un fichier Excel généré par un autre outil. Ce rapport comporte une fenêtre glissante de 4 semaines. Chaque semaine on montre les changements sur les 4 dernières semaine non compris la semaine courante, car les utilisateurs peuvent modifier leurs données 4 semaines en amont de la courante. Mon but est d'automatiser le plus possible la production de ce rapport. Un appui sur un bouton et je lance la génération. Le TCD est le modèle choisi. Voilà pourquoi le programmer en VBA (une fois l'effort fait) m'a semblé plus souple.

    Cordialement
    clem256

  7. #7
    Expert éminent

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 591
    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 591
    Par défaut
    Bonjour

    La bonne méthode est d'avoir un TCD dans un classeur qui utilise les données du fichier exporté sans les importer : l'actualisation suffit alors.

  8. #8
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    La démarche que je préconise te permet cela sans soucis. Chris, que je salue au passage, dit la même chose autrement
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  9. #9
    Membre confirmé
    Homme Profil pro
    Chef de projet Informatique
    Inscrit en
    Mai 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Chef de projet Informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2013
    Messages : 72
    Par défaut
    Merci. J'ai dû m'absenter, mais je reviens pourvous remercier de vos conseils/astuces. J'en prends bonne note et considère que le case est résolu.

    Clem256

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

Discussions similaires

  1. SQL : Création d'un tableau croisé dynamique
    Par chaporon dans le forum SQL
    Réponses: 11
    Dernier message: 17/05/2017, 22h25
  2. [AC-2007] Création d'un Tableau Croisé Dynamique (TCD) Excel depuis VBA Access
    Par Largo38 dans le forum VBA Access
    Réponses: 0
    Dernier message: 17/07/2013, 13h36
  3. Création d'un tableau croisé dynamique avec base données variable
    Par div20 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 15/01/2012, 00h43
  4. Réponses: 2
    Dernier message: 04/11/2010, 18h42
  5. Réponses: 4
    Dernier message: 31/07/2007, 15h34

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