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 :

Erreur SerieCollection et _chart


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mai 2010
    Messages
    193
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 193
    Par défaut Erreur SerieCollection et _chart
    Bonjour,

    Cela fait plusieurs jours que j'ai l'erreur suivante...
    J'ai du mal à comprendre pourquoi, des fois cela fait l'erreur des fois nan...
    Lorsque que j'ai crée le graphique j'ai

    "La méthode 'SerieCollection' de l'objet '_Chart' a échoué erreur 1004"

    Je suppose que c'est le fait que la macro n'arrive pas a choper le grpahique mais je ne vois pas comment faire mieux pour qu'elle le sélectionne...

    Nom : erreur chart.JPG
Affichages : 77
Taille : 11,0 Ko

    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
    Sub creation_diagramme(total_dd, total_dnd, total_di, total_deee, feuille_de_donnee As String)
        Worksheets(feuille_de_donnee).Activate
     
        Charts.Add
        ActiveChart.ChartType = xlPie
        ActiveChart.SeriesCollection(1).XValues = Array("DD", "DND", "DI", "DEEE")
        ActiveChart.SeriesCollection(1).Values = Array(total_dd, total_dnd, total_di, total_deee)
        ActiveChart.SeriesCollection(1).Name = "=""Répartition des déchets"""
        ActiveChart.SeriesCollection(1).Points(1).Interior.ColorIndex = dechet_dangereux
        ActiveChart.SeriesCollection(1).Points(2).Interior.ColorIndex = dechet_non_dangereux
        ActiveChart.SeriesCollection(1).Points(3).Interior.ColorIndex = dechet_inerte
        ActiveChart.SeriesCollection(1).Points(4).Interior.ColorIndex = dechet_electique
        ActiveChart.Location Where:=xlLocationAsNewSheet, Name:="Répartition des déchets"
        ActiveChart.Deselect
     
    End Sub
    Merci pour votre futur aide,


    Edit : J'ai 0 SeriesCollection, je ne sais pas pourquoi..

  2. #2
    Membre Expert
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2009
    Messages : 652
    Par défaut
    Bonjour,

    Peut être une piste avec :
    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 creation_diagramme(total_dd, total_dnd, total_di, total_deee, feuille_de_donnee As String)
        Worksheets(feuille_de_donnee).Activate
     
        Charts.Add
        ActiveChart.ChartType = xlPie
     
    '--- il faut ajouter l'instruction suivante en adaptant le Range concerné ---
       ActiveChart.SeriesCollection.Add Source:=ActiveWorkbook.Worksheets(feuille_de_donnee).Range("B1:B10")
     
     
        ActiveChart.SeriesCollection(1).XValues = Array("DD", "DND", "DI", "DEEE")
        ActiveChart.SeriesCollection(1).Values = Array(total_dd, total_dnd, total_di, total_deee)
        ActiveChart.SeriesCollection(1).Name = "=""Répartition des déchets"""
        ActiveChart.SeriesCollection(1).Points(1).Interior.ColorIndex = dechet_dangereux
        ActiveChart.SeriesCollection(1).Points(2).Interior.ColorIndex = dechet_non_dangereux
        ActiveChart.SeriesCollection(1).Points(3).Interior.ColorIndex = dechet_inerte
        ActiveChart.SeriesCollection(1).Points(4).Interior.ColorIndex = dechet_electique
        ActiveChart.Location Where:=xlLocationAsNewSheet, Name:="Répartition des déchets"
        ActiveChart.Deselect
     
    End Sub

  3. #3
    Membre confirmé
    Inscrit en
    Mai 2010
    Messages
    193
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 193
    Par défaut
    Le problème c'est qu'il n'y a pas du tout besoins de données dans des cellules enfaite...
    J'ai directement les résultats dans des variables.

    Je vais essayer de mettre un range imaginaire.

    Ce que je comprend pas c'est que la j'ai testé 15 fois aucune erreur et en refaisant la même chose ca vient de me le refaire plusieurs fois d'affilé...

  4. #4
    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
    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
    Sub Creation_Diagramme(ByVal Total_dd As Double, ByVal Total_dnd As Double, ByVal Total_di As Double, ByVal Total_deee As Double)
    Const StrNom As String = "Répartition des déchets"
    Dim Sr As Series
     
    Application.ScreenUpdating = False
    'Pour supprimer d'abord l'éventuelle feuille graphique
    '---------------------------
    On Error Resume Next
    Application.DisplayAlerts = False
    ThisWorkbook.Sheets(StrNom).Delete
    Application.DisplayAlerts = True
    On Error GoTo 0
    '---------------------------
     
    With ThisWorkbook.Charts.Add
        .Name = StrNom
        .ChartType = xlPie
     
        If .SeriesCollection.Count = 0 Then
            Set Sr = .SeriesCollection.NewSeries
        Else
            Set Sr = .SeriesCollection(1)
        End If
     
        With Sr
            .XValues = Array("DD", "DND", "DI", "DEEE")
            .Values = Array(Total_dd, Total_dnd, Total_di, Total_deee)
            .Name = StrNom
            .Points(1).Interior.ColorIndex = 9       'dechet_dangereux
            .Points(2).Interior.ColorIndex = 11      'dechet_non_dangereux
            .Points(3).Interior.ColorIndex = 26      'dechet_inerte
            .Points(4).Interior.ColorIndex = 37      'dechet_electique
        End With
    End With
    End Sub

  5. #5
    Membre confirmé
    Inscrit en
    Mai 2010
    Messages
    193
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 193
    Par défaut
    Ça marche parfaitement pour le moment.

    Le code est propre je savais pas que l'on pouvait faire "NewSeries".

    merci

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

Discussions similaires

  1. Erreur fréquente avec ASP et IIS
    Par Community Management dans le forum ASP
    Réponses: 2
    Dernier message: 11/02/2004, 22h20
  2. Check Url pour savoir si erreur 404 ou si le site existe
    Par Clément[Delphi] dans le forum Composants VCL
    Réponses: 2
    Dernier message: 07/08/2002, 13h49
  3. Réponses: 2
    Dernier message: 27/05/2002, 19h46
  4. erreur IDL:omg.org/CORBA/MARSHAL:1.0
    Par Pinggui dans le forum CORBA
    Réponses: 3
    Dernier message: 13/05/2002, 15h05
  5. [Kylix] Erreur objet
    Par Anonymous dans le forum EDI
    Réponses: 1
    Dernier message: 22/03/2002, 09h41

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