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 :

Faire varier les plages d'un graphique avec du code vba?


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    116
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 116
    Points : 43
    Points
    43
    Par défaut Faire varier les plages d'un graphique avec du code vba?
    Je cherche à faire varier les plages que doit utiliser mon graphique en fonction du code. (Dans mon cas, X champs appartenant à la plage A1:A12 peuvent être vide, j'aimerais les éliminer du graphique).
    C'est possible?
    merci !

  2. #2
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 756
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 756
    Points : 9 402
    Points
    9 402
    Par défaut
    Peut être avec un truc comme ca.
    Ca fonctionne mais c'est à améliorer

    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
     
    Dim i As Byte
     
    For i = 3 To 14 'Ligne a tester en valeur
        If Range("C" & i).Value = 0 Then GoTo suite
    Next i
     
    suite:
     
    If i > 3 Then i = i - 1
     
    ActiveSheet.ChartObjects("Graphique 1").Activate
    ActiveChart.SeriesCollection(1).Select
    ActiveChart.SetSourceData Source:=Sheets("Feuil1").Range("C3:C" & i), PlotBy:= _
        xlColumns

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    116
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 116
    Points : 43
    Points
    43
    Par défaut
    Question probablement bête, mais comment on fait pour ne pas modifier les valeurs sources de l'axe des abscisses? Là ça me supprime ma série et ça en recrée une nouvelle et je perds mes données sources d'axe...

  4. #4
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 756
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 756
    Points : 9 402
    Points
    9 402
    Par défaut
    Tu ajoutes ce code après la mise a jour de la plage de donnée en recalant ta plage d'étiquette d'abscisse

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ActiveChart.SeriesCollection(1).XValues = "=Feuil1!R3C2:R14C2"

Discussions similaires

  1. Faire varier les champs dans une requete
    Par kervin dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 10/09/2014, 12h58
  2. Réponses: 1
    Dernier message: 09/07/2012, 11h53
  3. faire varier les colonnes dans le produit scalaire
    Par erlerwade dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 09/08/2011, 17h27
  4. faire varier les variables
    Par PAYASS59 dans le forum PL/SQL
    Réponses: 6
    Dernier message: 16/03/2011, 19h56
  5. faire varier l'amplitude d'un son avec soundsc
    Par patrick7413 dans le forum Signal
    Réponses: 9
    Dernier message: 17/07/2008, 14h39

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