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 :

[VBA-E] référence colonne en fonction de son index et inversement


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier
    Inscrit en
    Mai 2006
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 8
    Par défaut [VBA-E] référence colonne en fonction de son index et inversement
    Je n'ai pas trouvé dans l'aide...

    Comment obtenir la référence de la colonne n ?

    Ex: Si n=40 je veux que ça me retourne "AN", de même que si je sais "AN", je veux que ça me retourne 40.

  2. #2
    Membre émérite
    Inscrit en
    Septembre 2005
    Messages
    617
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 617
    Par défaut
    Dénomination de colonne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    NoColonne=40
    DenomCol = Left$(cells(1,NoColonne).Address(0, 0), (NoColonne < 27) + 2)
    No de colonne


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    DenomCol="AN"
    NoColonne  = Range(DenomCol & "1").Column

  3. #3
    Membre régulier
    Inscrit en
    Mai 2006
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 8
    Par défaut
    Pour l'index en fonction de la référence, c'est exactement ce que je voulais

    Pour la référence en fonction de l'index, j'avais déjà fait en truc dans le genre mais je pensais qu'il y avait une solution plus élégante.

    En tout cas, merci


    (je ne mets pas ce topic tout de suite en "résolu", au cas où la solution "élégante" existe )

  4. #4
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Par défaut
    =SI(ENT(index/26)>0;CAR(ENT(index/26)+64);"")&CAR(MOD(index;26)+64)

  5. #5
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Par défaut
    =colonne(ref & 1)

  6. #6
    Membre régulier
    Inscrit en
    Mai 2006
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 8
    Par défaut
    oui on a aussi:

    =left(Feuil1.Columns(n).Address(columnAbsolute:=False),IIF(n>26,2,1))

    Mais bon, ce que je veux dire par élégant, c'est l'utilisation d'une propriété, style:

    =Feuil1.Columns(n).name ou Feuil1.Columns(n).ref

    Mais bon, ça fait plus d'une heure que je cherche, je crois que je vais laisser tomber

  7. #7
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Par défaut
    =colonne(ref & 1) tu peux remplacer par columns(ref & 1)
    c'est aussi élégant (enfin je trouve)

    nb le nom de la feuille n'a rien à voir la dedans
    b=2 indépdendemment de la feuille

  8. #8
    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
    J'ai trouvé ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox Split(Columns(40).Address(0, 0), ":")(0)
    Je trouve ça relativement "propre".

    Edit:
    Et, dans l'autre sens:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox Columns("AN").Column
    me paraît très "soft" aussi...
    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!

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

Discussions similaires

  1. [AC-2007] Renommer une colonne en fonction de son contenu
    Par guyCnet dans le forum VBA Access
    Réponses: 3
    Dernier message: 20/08/2010, 18h51
  2. Réponses: 7
    Dernier message: 08/02/2010, 17h25
  3. [VBA-E]Connaitre la lettre de la colonne en fonction du numero
    Par illight dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 07/01/2008, 12h32
  4. [VBA-E] Pb Comparaison De Deux Colonnes Avec Fonction If
    Par gromorice dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 23/03/2007, 05h57
  5. [VBA-E] référence Pour fonction Excel
    Par illight dans le forum Macros et VBA Excel
    Réponses: 17
    Dernier message: 19/04/2006, 14h29

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