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 :

Conversion plage cellule à partir d'index


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Homme Profil pro
    Ingénieur validation
    Inscrit en
    Octobre 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur validation
    Secteur : Transports

    Informations forums :
    Inscription : Octobre 2012
    Messages : 4
    Par défaut Conversion plage cellule à partir d'index
    Bonjour à tous

    J'ai un code qui me recupére des index de cellules et j'ai des difficultés à convertir mes données en adresse notamment pour les range (plage de cellule)

    par exemple

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    nbrligne=10
    nbrcolonne=4
    indexcolonne=3
     
    'plageglobale("A1:D10")
    plageglobale=Wb.ws.range(cells(1,1),cells(10,4))
     
    'colonnesansentête("C2:C10")
    colonnesansentête=Wb.ws.range(cells(2,3),cells(10,3))
    Je me cherche sur l'écriture:
    -utilisation d'address
    -utilisation split
    -type de donnée (string,range...)
    -définition de range
    - type pour chaque donnée
    -gestion en string ""&""

    C'est un problème que je rencontre de nombreuses fois et je n'ai pas trouvé d'explication claire sur la manière de procéder


    D'avance,merci

  2. #2
    Expert éminent


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Par défaut
    Bonsoir,


    et qu'est censé faire ton code ?

  3. #3
    Modérateur
    Avatar de AlainTech
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mai 2005
    Messages
    4 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2005
    Messages : 4 235
    Par défaut
    Bonjour,

    Un Range est un objet, il faut donc un Set.
    De plus, si ws est défini, inutile de le préfixer de Wb.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set plageglobale = ws.Range(Cells(1, 1),Cells(10, 4))
    Attention aux noms de variables avec accent...
    N'oubliez pas de cliquer sur quand vous avez obtenu ou trouvé vous-même la réponse à votre question.
    Si vous trouvez seul, pensez à poster votre solution. Elle peut servir à d'autres!
    Pensez aussi à voter pour les réponses qui vous ont aidés.
    ------------
    Je dois beaucoup de mes connaissances à mes erreurs!

  4. #4
    Membre à l'essai
    Homme Profil pro
    Ingénieur validation
    Inscrit en
    Octobre 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur validation
    Secteur : Transports

    Informations forums :
    Inscription : Octobre 2012
    Messages : 4
    Par défaut mise à jour avec set: ça ne fonctionne pas
    Merci pour les premieres pistes.

    Un extrait de mon code ( tri de plages qui sont susceptibles de changer de dimensions)

    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
     
    Dim plageentetecolonne As range
    Dim plageentete As range
    Dim plageglobale As range
    Dim nbr... As integer
     
    Set plageentetecolonne = WB_B2B.Sheets(4).Range(Cells(1, 2), Cells(1, nbrcolonnesimu1 + nbrcolonnecode1 - 1)).Columns
    Set plageentete = WB_B2B.Sheets(4).Range(Cells(1, 2), Cells(1, nbrcolonnesimu1 + nbrcolonnecode1 - 1))
    Set plageglobale = WB_B2B.Sheets(4).Range(Cells(1, 2), Cells(nbrminlignecomparaison, nbrcolonnesimu1 + nbrcolonnecode1 - 1))
     
    WB_B2B.Sheets(4).plageentetecolonne.Select
    WB_B2B.Sheets(4).Sort.SortFields.Clear
    WB_B2B.Sheets(4).Sort.SortFields.Add Key:=plageentete, SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:=xlSortNormal
        With WB_B2B.Sheets(4).Sort
            .SetRange plageglobale
            .Header = xlYes
            .MatchCase = False
            .Orientation = xlLeftToRight
            .SortMethod = xlPinYin
            .Apply
        End With

Discussions similaires

  1. [XL-2013] copier plage cellule a partir d'une variable
    Par Florian53 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 02/06/2015, 19h54
  2. [XL-2007] Actions sur plages / cellules non contigues définies à partir d'une ligne active
    Par Barbenault dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 06/10/2014, 11h33
  3. Réponses: 7
    Dernier message: 16/01/2014, 14h49
  4. Conversion plage de cellule en matrice
    Par Yomisha dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 30/11/2013, 22h48
  5. Auto completion d'une cellule à partir d'une plage nommée
    Par p2n2k2 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 26/01/2009, 17h52

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