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 :

Récupérer la valeur des champs d'un TCD [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Septembre 2011
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8
    Par défaut Récupérer la valeur des champs d'un TCD
    Bonjour à tous,

    J'ai réalisé un fichier qui permet de créer automatiquement des tableaux croisés dynamiques dans Excel (le fichier est disponible en pièce jointe avec des données simplifiées).

    Une première procédure permet, à partir d'une table de données et de 4 tables contenant la description des éléments constitutifs d'un TCD (nom du TCD, liste des étiquettes de lignes, liste des champs de valeur et liste des champs de filtres) de créer automatiquement une série de TCD. Cette fonction marche parfaitement.

    J'ai également rédigé une procédure dont le but est de récupérer les informations d'une série de TCD. L'intérêt est de pouvoir les récréer ensuite très facilement avec la procédure décrite ci-dessus.

    Je récupère sans problème le nom du TCD, la liste des étiquettes de lignes et la liste des champs de filtre (à l'aide des propriétés RowFields et PageFields. Cependant, je ne parviens pas à récupérer correctement le nom des champs de valeurs.

    J'utilise actuellement la propriété DataFields. Celle-ci permet d'obtenir le "caption" du champ de valeur mais pas son nom propre, que je ne parviens pas à trouver. Ainsi, je récupère "Somme de CHAMP1" à la place de CHAMP1.

    De plus, j'aimerais connaître l'opération d'aggrégation appliquée au champ de valeurs (nombre, somme ou moyenne).

    Si quelqu'un pouvait m'indiquer comment procéder, je lui en serai très reconnaissant ! Je cherche désespérément depuis plusieurs heures

    Merci d'avance
    neozen
    Fichiers attachés Fichiers attachés

  2. #2
    Expert éminent

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

    Le nom du champ d'origine est dans la propriété SourceName et le calcul dans Function.

    Pour les fonctions il faut une table de correspondance car Excel renvoie une valeur : -4112 pour un count.

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Septembre 2011
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8
    Par défaut
    Super, un grand merci Chris !!!

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 19/03/2008, 11h11
  2. Réponses: 2
    Dernier message: 11/12/2006, 12h38
  3. [MySQL] Je veux récupérer la valeur des champs de ma base et je n'ai qu'1 seul caractère
    Par yiuche dans le forum PHP & Base de données
    Réponses: 15
    Dernier message: 03/08/2006, 17h05
  4. Récupérer la valeur des champs calculés dans une requète SQL dans vba
    Par FrédéricCM dans le forum Requêtes et SQL.
    Réponses: 12
    Dernier message: 28/06/2006, 16h29
  5. Récupérer les valeurs des champs créés dynamiquement
    Par outlawz dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 03/05/2006, 16h32

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