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 :

Sélection plage de données [XL-2003]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 16
    Par défaut Sélection plage de données
    Bonjour à tous,

    Je débute en VBA et je me trouve devant un problème que je n'arrive pas à résoudre malgré les nombreuses aides sur les forum.

    Je souhaite sélectionner une plage de données mais les numéros de lignes et de colonnes sont variables

    Voici le code qui ne fonctionne pas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Set maplage = Sheets(seg).Range(Cells(lig1, 1), Cells(lig2, nbrcol))
    maplage.Select
    La définition de lig1, lig2 et nbrcol fonctionne sans souci mais lorque j'execute cette ligne j'ai l'erreur suivante :
    " Erreur définie par l'application et par l'objet"

    J'ai essayé beaucoup de codes différents sans succès.

    Merci de votre aide.

    Pauline.

  2. #2
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonjour,

    essayes comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    With Sheets("seg") ' si seg est le nom d'une feuille
      Set maplage = .Range(.cells(lig1, 1), .cells(lig2, nbrcol))
      maplage.Select 'ok mais "select" pour faire quoi ?
    End With
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  3. #3
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 16
    Par défaut
    Merci de cette réponse rapide.

    Je souhaite sélectionner cette plage pour après faire un graphique

    seg est un nom de variable qui contient le nom de mes feuilles c'est pour cela que je ne mettais pas de guillemets.

    Lorsque j'execute ton code j'ai l'erreur suivante :

    "la methode select de la classe range a échoué"

  4. #4
    Invité
    Invité(e)
    Par défaut Bonjour, regarde ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set maplage = Sheets("seg").UsedRange
    Fichiers attachés Fichiers attachés

  5. #5
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 16
    Par défaut
    Merci de vos réponses mais j'ai finalement trouvé la solution en mettant ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Sheets(seg).Select ' seg est le nom d'une variable
     Set maplage = ActiveSheet.Range(ActiveSheet.Cells(lig1, 1), ActiveSheet.Cells(lig2, nbrcol))
    A priori, ce problème venait du fait que ce code est écrit sur une autre feuille que seg, excel essayait donc de sélectionner des lignes de cette autre feuille dans la feuille seg. Je ne suis pas ure d'être très clair, je suis novice et je n'ai moi même pas très bien compris la solution.

    En tout cas ça fonctionne c'est le principale !

    merci encore!

  6. #6
    Invité
    Invité(e)
    Par défaut
    Sauf que l'usage des '.Select' est déconseillé.

    Tu peux très bien faire la même chose avec ce code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    With Sheets(seg)
      Set maplage = .Range(.Cells(lig1, 1), .Cells(lig2, nbrcol))
    End With

  7. #7
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    donc, je t'avais bien orienté sans passer par "Select" pour la feuille
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Sheets(seg).Select ' seg est le nom d'une variable
    Set maplage = ActiveSheet.Range(ActiveSheet.Cells(lig1, 1), ActiveSheet.Cells(lig2, nbrcol))
    peut devenir
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    With Sheets(seg) ' seg est le nom d'une variable
       Set maplage = .Range(.Cells(lig1, 1), .Cells(lig2, nbrcol))
    End With
    Edit : Je n'ai pas vu ta réponse Vcottineau
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

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

Discussions similaires

  1. Réponses: 17
    Dernier message: 27/02/2014, 21h29
  2. [XL-2010] Sélection de plusieurs plages de données pour un graphique : erreur macro
    Par Piixx_e dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 09/12/2013, 11h05
  3. Pb de sélection d'une plage de donnée
    Par rob1son76 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 02/02/2012, 18h08
  4. [XL-2003] faire une sélection dans une plage de données pour renseigner une liste de choix
    Par tremens dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 29/03/2010, 18h12
  5. Réponses: 1
    Dernier message: 09/03/2007, 07h52

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