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 - EXCEL (tableau croisé dynamique)


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Inscrit en
    Juillet 2005
    Messages
    41
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 41
    Points : 14
    Points
    14
    Par défaut VBA - EXCEL (tableau croisé dynamique)
    Bonjour, j'aimerais créer une macro qui se charge de créer un tableau croisé dynamique.

    Voici mon 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
    27
    28
    29
    30
    31
    32
    33
     
        ActiveWorkbook.PivotCaches.Add(SourceType:=xlDatabase, SourceData:= _
            "'O2C22 Daily CheckList'!R1C1:R557C31").CreatePivotTable TableDestination:="" _
            , TableName:="Tableau croisé dynamique"
        ActiveSheet.PivotTableWizard TableDestination:=ActiveSheet.Cells(3, 1)
        ActiveSheet.Cells(3, 1).Select
        ActiveSheet.PivotTables("Tableau croisé dynamique").SmallGrid = False
        With ActiveSheet.PivotTables("Tableau croisé dynamique").PivotFields( _
            "ORACLE ITEM CODE")
            .Orientation = xlRowField
            .Position = 1
        End With
        With ActiveSheet.PivotTables("Tableau croisé dynamique").PivotFields( _
            "ORDERED ITEM")
            .Orientation = xlRowField
            .Position = 2
        End With
        With ActiveSheet.PivotTables("Tableau croisé dynamique").PivotFields("LOT")
            .Orientation = xlRowField
            .Position = 3
        End With
        With ActiveSheet.PivotTables("Tableau croisé dynamique").PivotFields( _
            "SHIPPED QUANTITY")
            .Orientation = xlDataField
            .Position = 1
        End With
        Application.CommandBars("PivotTable").Visible = False
        ActiveSheet.PivotTables("Tableau croisé dynamique").PivotSelect _
            "'ORACLE ITEM CODE'[Tous;Somme]", xlDataAndLabel
        Selection.Delete
        ActiveSheet.PivotTables("Tableau croisé dynamique").PivotSelect _
            "'ORDERED ITEM'[Tous;Somme]", xlDataAndLabel
        Selection.Delete
    Tout se passe bien jusqu'à la ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
        ActiveSheet.PivotTables("Tableau croisé dynamique").PivotSelect _
            "'ORACLE ITEM CODE'[Tous;Somme]", xlDataAndLabel
    Là, j'ai un message d'erreur :
    Erreur d'exécution '1004':
    La formule est incomplète. Vérifiez qu'un crochet de fin ] ne manque pas.
    En fait cette ligne correspond à la sélection dans le tableau des lignes "somme" que l'on peut masquer à l'aide du clic droit -> masquer

    Je dois préciser que j'ai créé une macro "automatique" donc le code est généré automatiquement.

    Merci pour votre aide.

  2. #2
    Membre à l'essai
    Inscrit en
    Juillet 2005
    Messages
    41
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 41
    Points : 14
    Points
    14
    Par défaut
    Bon finalement je suis passé par une autre méthode pour résoudre mon problème et ça marche

    En fait j'ai remplacé le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
        ActiveSheet.PivotTables("Tableau croisé dynamique").PivotSelect _
            "'ORACLE ITEM CODE'[Tous;Somme]", xlDataAndLabel
        Selection.Delete
        ActiveSheet.PivotTables("Tableau croisé dynamique").PivotSelect _
            "'ORDERED ITEM'[Tous;Somme]", xlDataAndLabel
        Selection.Delete
    par celui-ci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
        ActiveSheet.PivotTables("Tableau croisé dynamique").PivotFields( _
            "ORACLE ITEM CODE").Subtotals = Array(False, False, False, False, False, False, False _
            , False, False, False, False, False)
        ActiveSheet.PivotTables("Tableau croisé dynamique").PivotFields("ORDERED ITEM" _
            ).Subtotals = Array(False, False, False, False, False, False, False, False, False, False _
            , False, False)
    Voilà, si ça peut aider certains...

    A bientôt !

  3. #3
    Candidat au Club
    Inscrit en
    Septembre 2007
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 3
    Points : 2
    Points
    2
    Par défaut j'ai trouvé une autre réponse
    il suffit de remplacer [Tous;Somme]
    par [All;Total]

    dans la macro VBA

    j'ai essayé cette solution parce que la solution d'avant n'a pas fonctionné avec moi. Peut etre parce que j'utilise EXCEL 2000

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

Discussions similaires

  1. Delphi/Ole/Excel/Tableau croisé dynamique
    Par Dunsany dans le forum API, COM et SDKs
    Réponses: 2
    Dernier message: 26/06/2009, 13h25
  2. excel tableau croisé dynamique
    Par JEFF28 dans le forum Excel
    Réponses: 2
    Dernier message: 19/12/2008, 15h19
  3. Excel Tableau Croisé Dynamique + Graphique
    Par levnath dans le forum Langage
    Réponses: 0
    Dernier message: 03/11/2008, 16h47
  4. VBA et tableau croisé dynamique = tutoriel ?
    Par Caps corp dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 26/09/2008, 11h52
  5. [Excel] Tableau croisé dynamique
    Par jbrasselet dans le forum Excel
    Réponses: 1
    Dernier message: 11/01/2008, 13h57

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