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éation d'un graphique via une macro


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    technicien laboratoire
    Inscrit en
    Juillet 2011
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : technicien laboratoire
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2011
    Messages : 1
    Par défaut création d'un graphique via une macro
    Bonjour,
    débutant sous VBA, je cherche à réaliser une macro qui me permet de créer un graphique à partir d'un fichier X.
    le programme obtenu est le suivant :

    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
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    Sub graph_macro_2()
    '
    ' graph_macro_2 Macro
    ' Macro enregistrée le 31/08/2011 par quintric
    '
    Charts.Add
    ActiveChart.ChartType = xlXYScatterSmoothNoMarkers
    ActiveChart.SetSourceData Source:=Sheets("Feuil1"). _
    Range("A18:B500"), PlotBy:=xlColumns
    ActiveChart.Location Where:=xlLocationAsNewSheet
    With ActiveChart
    .HasTitle = True
    .ChartTitle.Characters.Text = "courbe force course"
    .Axes(xlCategory, xlPrimary).HasTitle = True
    .Axes(xlCategory, xlPrimary).AxisTitle.Characters.Text = "course (mm)"
    .Axes(xlValue, xlPrimary).HasTitle = True
    .Axes(xlValue, xlPrimary).AxisTitle.Characters.Text = "force (N)"
    End With
    With ActiveChart.Axes(xlCategory)
    .HasMajorGridlines = True
    .HasMinorGridlines = True
    End With
    With ActiveChart.Axes(xlValue)
    .HasMajorGridlines = True
    .HasMinorGridlines = True
    End With
    ActiveChart.PlotArea.Select
    With Selection.Border
    .ColorIndex = 2
    .Weight = xlThin
    .LineStyle = xlContinuous
    End With
    With Selection.Interior
    .ColorIndex = 2
    .PatternColorIndex = 1
    .Pattern = xlSolid
    End With
    ActiveChart.ChartArea.Select
    ActiveChart.SeriesCollection(1).XValues = _
    "='Feuil1'!R18C2:R500C2"
    ActiveChart.SeriesCollection(1).Values = _
    "='Feuil1'!R18C1:R500C1"
    ActiveChart.Axes(xlValue).Select
    With Selection.Border
    .ColorIndex = 57
    .Weight = xlMedium
    .LineStyle = xlContinuous
    End With
    With Selection
    .MajorTickMark = xlOutside
    .MinorTickMark = xlNone
    .TickLabelPosition = xlNextToAxis
    End With
    ActiveChart.Axes(xlCategory).Select
    With Selection.Border
    .ColorIndex = 57
    .Weight = xlMedium
    .LineStyle = xlContinuous
    End With
    With Selection
    .MajorTickMark = xlOutside
    .MinorTickMark = xlNone
    .TickLabelPosition = xlNextToAxis
    End With
    With ActiveChart.Axes(xlCategory)
    .MinimumScale = 0
    .MaximumScaleIsAuto = True
    .MinorUnitIsAuto = True
    .MajorUnitIsAuto = True
    .Crosses = xlAutomatic
    .ReversePlotOrder = False
    .ScaleType = xlLinear
    .DisplayUnit = xlNone
    End With
    End Sub
    le programme fonctionne, seulement j'aurai besoin de remplacer Feuil1 automatiquement par le nom de celle du fichier a exploiter.
    dans ce fichier, il n'y a qu'un seul onglet nommé comme le nom de sauvegarde.

    pour résumer j'ai besoin que la macro s'exécute quelque soit le nom de la feuille qui contient mes mesures.

    je reste à votre disposition pour tous compléments d'information ou clarification du sujet.

    merci à vous

  2. #2
    Membre expérimenté
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    207
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 207
    Par défaut
    Remplace:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ActiveChart.SetSourceData Source:=Sheets("Feuil1")
    par:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ActiveChart.SetSourceData Source:=ActiveSheet
    Pour accélérer l'exécution de la macro, rajoute ceci au tout début du code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.ScreenUpdating = False
    Et cela à la fin:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.ScreenUpdating = True


    PS: n'oublie pas d'utiliser les balises [CODE] quand tu postes...

Discussions similaires

  1. [XL-2010] Problème: Création plusieure graphique grâce à une Macro Excel 2010
    Par abdel01 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 20/05/2015, 20h35
  2. [XL-2010] PB de création d'un graphique sur une feuille créée dans une macro
    Par ecailley dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 02/04/2013, 15h16
  3. configurer un graphique via une macro
    Par Lost_in_VBA dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 19/07/2011, 14h53
  4. [XL-2007] Création d'une image jpg via une Macro.
    Par djflnj dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 22/09/2010, 15h47
  5. [VBA-E]Filtre via une macro sur Excel
    Par jamal.b dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 26/04/2006, 15h35

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