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 :

Comment récupérer le contenu d'une cellule


Sujet :

Macros et VBA Excel

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    277
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 277
    Par défaut Comment récupérer le contenu d'une cellule
    Bonjour,

    J'ai créée une fonction VBExcel, qui me permet de manipuler un nombre passé en argument de la fonction. Voici son prototype:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Function ComputeLatitude(ByVal Value As String) As Double
    Je voudrais pouvoir appeler cette fonction depuis mon classeur Excel. De la manière suivante, par exemple lire la cellule D34
    Avec la cellule D34 égale à 7F1C (un nombre hexadécimal). J'obtiens l'erreur suivante : #VALEUR!

    Lorsque j'appelle cette fonction depuis le module VB de la manière suivante :
    ComputeLatitude("7F1C"), le calcul s'effectue correctement

    Et dans les deux fenêtres lorsque le contenu de la cellule/fonction n'est constitué que de chiffre, le résultat est correct.

    Je pense qu'il s'agit de mon argument d'entrée de la fonction qui pose problème : ByVal Value As String. J'ai donc essayé d'appeler la fonction depuis mon classeur Excel en forçant l'argument a être un String mais sans succès.

    Quelqu'un a une petite astuce à me conseiller,

    Merci

  2. #2
    Membre expérimenté
    Profil pro
    Développeur informatique
    Inscrit en
    Mars 2008
    Messages
    155
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2008
    Messages : 155
    Par défaut
    Pour retrouver la valeur d'une cellule
    Si tu veux être sur que ce soit du type string
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Cstr(Range("D34").value)

  3. #3
    pgz
    pgz est déconnecté
    Expert confirmé Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Par défaut
    Citation Envoyé par gronaze Voir le message
    Avec la cellule D34 égale à 7F1C (un nombre hexadécimal). J'obtiens l'erreur suivante : #VALEUR!

    Lorsque j'appelle cette fonction depuis le module VB de la manière suivante :
    ComputeLatitude("7F1C"), le calcul s'effectue correctement

    Et dans les deux fenêtres lorsque le contenu de la cellule/fonction n'est constitué que de chiffre, le résultat est correct.
    Voilà qui n'est pas banal.
    Si c'était l'inverse, on dirait que c'est un problème de type de la donnée passée en paramètre. Mais là...

    J'ai fait un test. Avec cette fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Function fctUneValeur(ByVal Value As String) As Double
        fctUneValeur = Len(Value) / 1.3
    End Function
    Si j'écris dans la cellule appelée 7F1C la valeur est considérée comme du texte et pas de pb. Si j'écris 8000, la valeur est considérée numérique et je n'ai pas de pb non plus...

    Par contre si je modifie la fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Function fctUneValeur(ByVal Value As String) As Double
        fctUneValeur = Len(Value) / 0
    End Function
    J'obtiens #Valeur.

    Je serai tenté de penser qu'il faut chercher du côté de la fonction, même si
    Lorsque j'appelle cette fonction depuis le module VB de la manière suivante :
    ComputeLatitude("7F1C"), le calcul s'effectue correctement
    PGZ

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 19/04/2009, 14h44
  2. Comment récupérer le contenu d'une URL dans une variable ?
    Par Fildz dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 28/08/2006, 10h26
  3. [VB.NET][FlexGrid]Récupérer le contenu d'une cellule de FlexGrid
    Par kinganasius dans le forum Windows Forms
    Réponses: 1
    Dernier message: 06/06/2006, 18h11
  4. [VB6]Comment centrer le contenu d'une cellule
    Par zackrel dans le forum VB 6 et antérieur
    Réponses: 15
    Dernier message: 19/05/2006, 21h02

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