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 :

Comment positionner une barre verticale sur un graphique [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2008
    Messages : 611
    Points : 359
    Points
    359
    Par défaut Comment positionner une barre verticale sur un graphique
    Bonjour,

    J'ai réalisé un graphique à partir de données contenues dans 2 colonnes:

    - Colonne A: concaténation de l'année & "/" & semaine,
    - Colonne B : nombre d'heures.

    En abscisses, j'ai positionné la colonne A et en ordonnées la colonne B.

    A présent, je souhaite positionner une barre verticale sur une certaine valeur de la colonne A que je suis à même de déterminer (semaine - 1 par rapport à la semaine en cours).

    J'ai regardé les différents topics sur ce sujet sur le web mais j'ai pas mal ,de lacunes sur VBA Excel.

    Comment puis-je m'y prendre ?

    Merci d'avance.

  2. #2
    Expert éminent sénior Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Points : 31 877
    Points
    31 877
    Par défaut
    Exemple
    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
    Sub Graphe()
    Dim LastLig As Long, i As Long
    Dim X As Range, Y As Range
    Dim Ch As ChartObject
    Dim Sem As String
    Dim Tb() As Double
     
    Application.ScreenUpdating = False
    With Worksheets("Feuil1")
        LastLig = .Cells(.Rows.Count, 1).End(xlUp).Row
        Set X = .Range("A1:A" & LastLig)
        Set Y = .Range("B1:B" & LastLig)
        Set Ch = .ChartObjects.Add(300, 50, 400, 250)
    End With
     
    With Ch.Chart
        .ChartType = xlLineStacked
        With .SeriesCollection.NewSeries
            .Values = Y
            .XValues = X
        End With
     
        'Semaine dernière sous forme ANNEE/N°SEMAINE
        Sem = Year(DateAdd("ww", -1, Date)) & "/" & DatePart("ww", DateAdd("ww", -1, Date), vbMonday)
     
        ReDim Tb(1 To LastLig)
        For i = 1 To LastLig
            Tb(i) = IIf(X(i) = Sem, Application.Max(Y), 0)
        Next i
        Set X = Nothing
        Set Y = Nothing
     
        With .SeriesCollection.NewSeries
            .Values = Tb
            .ChartType = xlColumnClustered
        End With
    End With
    Set Ch = Nothing
    End Sub

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 28/01/2014, 12h07
  2. Tracer une droite verticale sur un graphique
    Par AdiAccess dans le forum IHM
    Réponses: 1
    Dernier message: 04/03/2008, 12h05
  3. Comment tracer une ligne verticale dans un graphique
    Par developpeur82 dans le forum MATLAB
    Réponses: 3
    Dernier message: 03/04/2007, 14h06
  4. afficher une marque verticale sur un graphique XY
    Par micniv dans le forum Access
    Réponses: 1
    Dernier message: 06/04/2006, 09h50

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