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 :

Function et mise en forme [XL-2007]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 11
    Par défaut Function et mise en forme
    Bonjour,

    j'utilise une fonction qui me permet de calculer un prix moyen pondéré à partir d'un historique de prix.

    Tout fonctionne très bien mais je voudrais améliorer juste un point : la couleur des cellules utilisées pour calculer ce prix moyen pondéré.

    Je me demande si il n'y a pas une quelconque limitation.

    voici 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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    Public x
    
    Function GetPrice(isin, horodatage, quantity)
    
    Dim colQuant, colPrix, quantTemp, prixTemp, colFutures
    
    colPrix = 2
    colQuant = 3
    
    'On va déterminer où se trouve l'histo
    
    'Colonne
    Set FEUIL = ThisWorkbook.Sheets("HISTO")
    Set x = FEUIL.range("1:1").Find(isin)
    colFutures = x.Column
    
    'Ligne
    horodatageTemp = Format(horodatage, "dd/mm/yyyy hh:mm")
    Set y = range(FEUIL.Cells(2, colFutures), FEUIL.Cells(2, colFutures).End(xlDown))
    
    Call getLigne(horodatageTemp, y)
    
    rowTemp = x.Row
    Do While FEUIL.Cells(rowTemp, colFutures) < horodatage
     rowTemp = rowTemp + 1
    Loop
    FirstRow = rowTemp
      Do While quantTemp + FEUIL.Cells(rowTemp, colFutures + colQuant) <= quantity
      
      Call formatRange(FEUIL.Cells(rowTemp, colFutures))
        quantTemp = quantTemp + FEUIL.Cells(rowTemp, colFutures + colQuant)
        prixTemp = prixTemp + FEUIL.Cells(rowTemp, colFutures + colPrix) * FEUIL.Cells(rowTemp, colFutures + colQuant)
        rowTemp = rowTemp + 1
      Loop
      If quantTemp <> quantity Then
      
      residu = quantity - quantTemp
      prixTemp = prixTemp + FEUIL.Cells(rowTemp, colFutures + colPrix) * residu
      End If
    
    
    GetPrice = Round(prixTemp / quantity, 4)
    
    End Function
    
    
    Sub getLigne(data, r)
    Set x = r.Find(what:=data, LookIn:=xlValues)
    Do While x Is Nothing
      data = Format(data, "dd/mm/yyyy hh")
          Set x = r.Find(what:=data, LookIn:=xlValues)
    Loop
    End Sub
    
    
    Sub formatRange(r)
    r.Color = 3
    End Sub
    J'ai un probleme sur la ligne rouge quand on fait appel à la sub formatRange
    Ce qui m'étonne c'est que cela fonctionne lorsque je fais appel à cette sub à partir d'une autre sub.

    Merci d'avance

  2. #2
    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,

    Je ne connais pas de propriété Color d'un objet Range.
    Essaie ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub formatRange(r As Range)
      r.Interior.Color = 3
      ' ou plutôt
      r.Interior.ColorIndex = 3
    End Sub
    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!

  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
    Je viens seulement de comprendre cette phrase:
    Ce qui m'étonne c'est que cela fonctionne lorsque je fais appel à cette sub à partir d'une autre sub.
    Il n'est pas possible de faire une quelconque modification dans une feuille à partir d'une fonction appelée dans une cellule.
    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 habitué
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 11
    Par défaut
    Ok c'est bien ce que je pensais, merci

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

Discussions similaires

  1. Function - mise en forme
    Par aedcc dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 25/02/2014, 13h31
  2. [AC-2010] Function de mise en forme d'Excel qui plante une fois sur 2 ?
    Par _C14_ dans le forum VBA Access
    Réponses: 13
    Dernier message: 31/05/2012, 22h01
  3. mise en forme rapide d'applets
    Par appletj dans le forum Applets
    Réponses: 11
    Dernier message: 03/06/2004, 13h28
  4. Mise en forme HTML
    Par Regis.C dans le forum XML/XSL et SOAP
    Réponses: 5
    Dernier message: 25/04/2004, 11h55
  5. Mise en forme fichier avant Import
    Par jeff37 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 21/04/2004, 15h16

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