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 :

Utiliser Range avec un numéro de ligne et un numéro de colonne variables


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    59
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 59
    Points : 52
    Points
    52
    Par défaut Utiliser Range avec un numéro de ligne et un numéro de colonne variables
    Bonjour à tous!
    J'ai un problème pour sélectionner une plage de données en VBA pour en faire la source d'un graphique.
    La taille de mon tableau est variable et je n'arrive pas à saisir la totalité avec la fonction range!
    En gros, une partie de ma fonction a l'heure actuelle est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets("Stats_données").Range("A2:Z" & NumLign)
    Mais je ne voudrais pas mettre Z comme colonne limite du tableau mais le numéro de la colonne compris dans la valeur de la variable NumColonn.
    Je sais qu'il faut mettre une lettre pour la colonne dans Range(enfin, je crois!?), mais moi je n'ai que le numéro de colonne!
    Je sais que j'ai pas été super clair, mais si quelqu'un aurait une idée, je lui en serais super reconnaissant!
    Merci!
    Bonne journée!
    Bubale

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    117
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 117
    Points : 74
    Points
    74
    Par défaut
    Bonjour Bubale,
    J'ai eu le même souci et finalement j'ai utilisé ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets("Stats_données").Range(cells(2,1),cells(NumLign, NumCol))
    Voila, j'espère que cela correspond à ta demande.
    Cordialement.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    59
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 59
    Points : 52
    Points
    52
    Par défaut
    Merci, ca doit être un truc dans le genre si ca a marché chez toi, mais moi, il me met une erreur!
    je te donne ma formule, je suis sur que les variables sont les bonnes et contiennent une valeur (je les ai testées - elles sont définies as integer)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ActiveChart.SetSourceData Source:=Sheets("Stats_données").Range(Cells(2, 1), Cells(numlign, numcolonn))
    Je ne vois pas pourquoi ca marcherait pas! Vous voyez?
    Merci!

  4. #4
    Expert éminent
    Avatar de Lou Pitchoun
    Profil pro
    Inscrit en
    Février 2005
    Messages
    5 038
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Février 2005
    Messages : 5 038
    Points : 8 268
    Points
    8 268
    Par défaut
    Salut,

    Sans trop connaitre : la source d'un graphique est une adresse du style
    NomFeuille!A2:B6.

    Il te faut donc affecter le nom de la feuille et la page de cellule (ou adresse).

    Donc un truc du style serait plus approprié non ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ActiveChart.SetSourceData Source:=Sheets("Stats_données").Name & "!" & Sheets("Stats_données").Range(Cells(1, 1), Cells(numlign, numcolonn)).Address

  5. #5
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    3 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 3 317
    Points : 20 147
    Points
    20 147
    Par défaut
    bonjour

    En complément de la réponse de Papimcha, il faut également spécifier la feuille devant "Cells" :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Dim Ws As Worksheet
     
    Set Ws = Worksheets("Stats_données")
     
    objGraph.SetSourceData _
        Ws.Range(Ws.Cells(2, 1), Ws.Cells(NumLign, NumCol)), _
        xlColumns


    bonne journée
    michel

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    59
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 59
    Points : 52
    Points
    52
    Par défaut
    Ok, merci...la ca marche!!
    Ca me soulage bien..M E R C IIIIIIIIIIIIIIIIIIII
    Bonne journée!

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

Discussions similaires

  1. [XL-2013] Insertion de ligne jusqu'au numéro de ligne souhaité
    Par caswana dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 06/04/2014, 08h10
  2. [XL-2007] Utiliser la valeur d'une cellule comme numéro de ligne
    Par DiesIrae dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 11/08/2009, 14h04
  3. [Débutant] Ecrirer un fichier texte avec les numéros de ligne ?
    Par Krillz dans le forum MATLAB
    Réponses: 14
    Dernier message: 25/02/2009, 23h09
  4. RichTextBox marge avec numéro de ligne
    Par TERRIBLE dans le forum C#
    Réponses: 1
    Dernier message: 18/01/2009, 13h41
  5. Statistique : Numéro de ligne avec MySQL
    Par djédjé14 dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 05/09/2006, 10h02

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