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 :

Problème avec Formula, Index et EQUIV [XL-2007]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2015
    Messages : 43
    Par défaut Problème avec Formula, Index et EQUIV
    Bonjour,

    J'essaye de finaliser une macro avec dedans les fonctions Index et equiv.
    Les difficultés sont que je souhaite utiliser formula pour avoir la formule dans la cellule et j'utilise des variables.

    Le reste du code fonctionne, la ligne qui bug est celle avec index.

    Le code

    Ci-dessous le code
    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
     
    For g = 9 To 300
    While Cells(g, 3) <> ""
     
    Cells(g, e + 2).Formula = "=Min(" & Range(Cells(g, 5), Cells(g, e - 1)).Address & ")"
    Cells(g, e + 3).Formula = "=Max(" & Range(Cells(g, 5), Cells(g, e - 1)).Address & ")"
     
    If Cells(g, e).Value <> 0 And Cells(g, e).Value <> "" And Cells(g, e + 3).Value <> 0 Then
    Cells(g, e + 5).Value = (Cells(g, e + 3).Value) / (Cells(g, e).Value)
     
    Cells(g, e + 3).Formula = "=INDEX(" & Range(Cells(8, 5), Cells(8, e - 1)): Range(Cells(g, 5), Cells(g, e - 1)) & ",1," & "MATCH("&Cells(g, e + 3).value", & Range(Cells(g, 5), Cells(g, e - 1) &",0))"
     
    End If
     
    g = g + 1
     
    Wend
    Next
    En vous remerciant par avance

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Bonjour,

    2 choses:

    - Que vaut e lorsque tu passes à cette ligne?
    - Donne-nous la formule telle que tu l'inscrirais en français dans la barre de formule

  3. #3
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Regarde ton code : toute la fin est en rouge.
    Ca, c'est mauvais signe.

    L'éditeur de ce forum ne comporte pas (pas encore ?) de débugueur VBA mais il indique en rouge ce qui est entre guillemets.
    Si la zone rouge se poursuit au delà de ce qui était prévu, c'est que les guillemets sont en nombre impaire, ce qui est rarement fonctionnel.

    A mon avis, il en manque un juste avant ton dernier & Range.

    Mais il est étonnant que le VBE ait laissé passer ça (ce que confirme le value sans majuscule qui précède) ...

  4. #4
    Membre Expert
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 817
    Billets dans le blog
    10
    Par défaut
    Bonjour,
    Lors de concaténation avec &, ne surtout pas omettre l'espace avant le &.
    "MATCH" & Cells....

  5. #5
    Membre Expert
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 817
    Billets dans le blog
    10
    Par défaut
    J'ajoute également que le signe : au milieu des deux Range me semble étrange. Tout comme les 2 Range utilisés (au lieu de leurs propriétés Address).....

  6. #6
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2015
    Messages : 43
    Par défaut
    Bonjour,

    Excusez moi pour le délai de réponse.

    Pour parmi:
    e = Cells(8, Columns.Count).End(xlToLeft).Column

    Je souhaiterai écrire =INDEX($E$8:$H$10;1;EQUIV(L9;E9:H9;0)) sachant que mes variables interviennent (jamais le même nombre de colonnes d'où l'intervention de e et pouvoir le faire sur plusieurs ligne avec g).

    Pour menhir:
    Il y avait bien un problème de synthaxe, j'arrive maintenant à lancer le code, cependant il bug sur la ligne en question.

    Pour pijaku:

    Penses tu qu'il faut utiliser le .address?

    Voilà où en est le code:

    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
     
    For g = 9 To 300
    While Cells(g, 3) <> ""
     
    Cells(g, e + 2).Formula = "=Min(" & Range(Cells(g, 5), Cells(g, e - 1)).Address & ")"
    Cells(g, e + 3).Formula = "=Max(" & Range(Cells(g, 5), Cells(g, e - 1)).Address & ")"
     
     
     
    If Cells(g, e).Value <> 0 And Cells(g, e).Value <> "" And Cells(g, e + 3).Value <> 0 Then
    Cells(g, e + 5).Value = (Cells(g, e + 3).Value) / (Cells(g, e).Value)
     
    Cells(g, e + 3).Formula = "=INDEX(" & Range(Cells(8, 5), Cells(8, e - 1)) & ":" & Range(Cells(g, 5), Cells(g, e - 1)) & ",1," & "MATCH(" & Cells(g, e + 3).Value & "," & Range(Cells(g, 5), Cells(g, e - 1)) & ",0))"
     
    End If
     
    g = g + 1
     
    Wend
    Next
    En vous remerciant,

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

Discussions similaires

  1. Problème avec "formula" sur un property
    Par nighthammer dans le forum Hibernate
    Réponses: 8
    Dernier message: 11/07/2007, 16h00
  2. Problème avec z-index
    Par Death83 dans le forum Mise en page CSS
    Réponses: 7
    Dernier message: 09/10/2006, 12h23
  3. CSS problème avec z-index sous mozilla
    Par stringdrid dans le forum Mise en page CSS
    Réponses: 1
    Dernier message: 16/05/2006, 09h59
  4. Problème avec les indexes sur une base de données.
    Par osoudee dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 09/02/2006, 09h24
  5. problème avec z-index sous firefox ???
    Par SpaceFrog dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 22/09/2005, 20h39

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