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éer un graphique


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2014
    Messages : 3
    Par défaut Créer un graphique
    Bonjour,
    J'ai passé la matinée à essayer de comprendre mon erreur sans succès.
    Le but est de créer un graphique à partir de données présentes sur la feuille et en passant ainsi en revue 47 feuilles de mon classeur (dont les noms sont : "1", "2", etc).
    J'ai essayé divers syntaxes, dont la dernière que je vous présente ici et que la plupart des gens ont l'air d'utiliser. Au passage, si vous avez une proposition de code sans passer par activechart ce serait formidable.
    Malgré la simplicité de la demande, je suis coincée. J'espère que vous pourrez m'aider...
    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
    Public Sub Graphiques()
     
    Dim feuillexploit As Integer
    Dim feuillexploitstr As String
    Dim ligne As Integer
    Dim x As String
    Dim y As String
    Dim r As Range
     
    For feuillexploit = 2 To 47
    <div style="margin-left:40px">feuillexploitstr = CStr(feuillexploit)
    Sheets(feuillexploitstr).Shapes.AddChart
    Set r = Sheets(feuillexploitstr).Range("G2:I16")
    ActiveChart.SetSourceData Source:=r 'C'est à cette ligne que ça coince
    ActiveChart.ChartType = xlColumnStacked
    ActiveChart.SeriesCollection(1).XValues = Sheets(feuillexploitstr).Range(Cells(2, 1), Cells(16, 1))</div>Next
    End Sub

  2. #2
    Expert éminent 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
    Par défaut
    Peut être comme ceci
    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
    Sub Graphiques()
    Dim Ch As Chart
    Dim Sr As Series
    Dim i As Integer
    Dim k As Byte
     
    For i = 2 To 47
        With Worksheets(CStr(i))
            Set Ch = .ChartObjects.Add(100, 100, 500, 350).Chart
            Ch.ChartType = xlColumnStacked
     
            For k = 0 To 1
                Set Sr = Ch.SeriesCollection.NewSeries
                Sr.XValues = .Range("A2:A16")
                Sr.Values = .Range("G2:G16").Offset(, k)
                Set Sr = Nothing
            Next k
            Set Ch = Nothing
        End With
    Next i
    End Sub

  3. #3
    Futur Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2014
    Messages : 3
    Par défaut
    Super, merci beaucoup !
    Au moins, ça se déroule et je vais essayer de l'adapter pour avoir le graphique que je veux.
    Quand savoir s'il faut utiliser "with" et "set" ? Qu'est ce que sont les objets ou types de données series et byte ?

  4. #4
    Membre Expert Avatar de Gado2600
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Mai 2013
    Messages
    904
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Office VBA

    Informations forums :
    Inscription : Mai 2013
    Messages : 904
    Par défaut
    Le set est pour attribuer une variable à un objet afin de l'utiliser plus tard.
    Exemples :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    dim rec as dao.recordset
    set rec = currentdb.openrecordset("Nom_Table", dbopendynaset)
    rec.fields(1).value = 1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    dim oOutlook as Outlook.Application
    set oOutlook = createboject("Outlook.Application")
    le with sert plutôt pour éviter de répéter de grands appels
    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    pptActivepresentation.slides(1).shapes(1).textframe.textrange.text = "Alpha"
    pptActivepresentation.slides(1).shapes(2).textframe.textrange.text = "Beta"
    pptActivepresentation.slides(1).shapes(3).textframe.textrange.text = "Delta"
    pptActivepresentation.slides(1).shapes(4).textframe.textrange.text = "Gamma"
    peut se remplacer par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    with pptActivepresentation.slides(1)
         .shapes(1).textframe.textrange.text = "Alpha"
         .shapes(2).textframe.textrange.text = "Beta"
         .shapes(3).textframe.textrange.text = "Delta"
         .shapes(4).textframe.textrange.text = "Gamma"
    end with
    Le set et le with peuvent se cumuler dans le besoin.

    Cordialement,

  5. #5
    Futur Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2014
    Messages : 3
    Par défaut
    Un grand merci à tous les deux : j'aurai appris quelque chose aujourd'hui !

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

Discussions similaires

  1. Créer un graphique
    Par daninho dans le forum 2D
    Réponses: 6
    Dernier message: 15/03/2006, 23h48
  2. Créer des graphiques
    Par zorba49 dans le forum ASP
    Réponses: 3
    Dernier message: 21/02/2006, 10h14
  3. [Graphique] Créer des graphiques en PHP
    Par neXistPa dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 08/01/2006, 13h26
  4. Réponses: 31
    Dernier message: 28/03/2005, 17h23
  5. Créer un graphique en GIF sous DELPHI pour du web
    Par Thom@s dans le forum Web & réseau
    Réponses: 20
    Dernier message: 08/07/2004, 15h40

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