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

VBA Access Discussion :

convertir un texte (1.114,28-) en nombre décimal


Sujet :

VBA Access

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Août 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 2
    Par défaut convertir un texte (1.114,28-) en nombre décimal
    Bonjour,
    A partir d'une table attachée en txt, je recupére des valeurs numériques avec le signe négatif à la fin et un point en séparateur des milliers, par ex :
    1.114,28-
    3.000,00
    1.344,00-

    J'aimerais savoir s'il existe une fonction ou une procédure que je pourrais utiliser à partir d'une requete afin d'obtenir un nombre décimal normal.
    J'ai essayé d'adapter la fonction replace et d'autres, en vain, c'est trop compliqué pour moi.

    Merci d'avance pour votre aide


  2. #2
    Expert confirmé
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Par défaut
    Hello,

    un exemple à tester
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Function Nettoyage(byval str as string) As Double
     
    Str = Replace(Str, ".", VbNullString)
    Str = Replace(Str, ",", ".")
    If Right(Str, 1) = "-" Then
        Nettoyage = CDbl("-" & Left(Str, Len(Str) - 1))
    Else
        Nettoyage = CDbl(Str)
    End If
     
    End Function

  3. #3
    Membre Expert
    Avatar de mout1234
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    2 210
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 2 210
    Par défaut
    Bonjour et bienvenu sur le forum.

    Je ne crois qu'il y ait de solutions toute faite.

    Plutot que d'essayer de te guider... je t'ai écris une solution (peu testée)

    Place ce code dans un module standard:
    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
    Public Function ap_FormaterNombres(ByVal vValeur As Variant) As Double
    On Error Resume Next
     
    Dim sNombre As String
    Dim iSigne  As Double
    If Nz(vValeur, 0) = 0 Then
        'valeur nulles ou égales à 0
        ap_FormaterNombres = 0
    Else
        'Isoler le signe
        If Right(vValeur, 1) = "-" Then
            sNombre = Left(vValeur, Len(vValeur) - 1)
            iSigne = -1
        Else
            sNombre = vValeur
            iSigne = 1
        End If
     
        sNombre = Replace(Replace(sNombre, ".", ""), ",", ".")
     
     
        ap_FormaterNombres = iSigne * val(sNombre)
     
    End If
    End Function
    Tu peux alors utiliser la fonction ap_FormaterNombres dans une requête. Quelque chose du genre:

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT ap_FormaterNombres([MonChamp]) as NombreFormaté FROM Matable

    EDIT: Cafeine a répondu plus vite et te propose un code plus concis ... mais la logique est la même.

    BOn dev

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Août 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 2
    Par défaut
    Merci à vous deux pour votre rapidité et surtout pour votre efficacité.

    C'est paefait, ça marche et ça répond tout à fait à ce que je voulais obtenir.


    Merci mille fois


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

Discussions similaires

  1. Convertir du texte en nombres dans un SUMPRODUCT (SOMMEPROD)
    Par IAmByB dans le forum Macros et VBA Excel
    Réponses: 18
    Dernier message: 24/04/2014, 16h48
  2. Convertir texte en nombre décimal
    Par InfoGeo dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 18/11/2013, 16h42
  3. [XL-2007] Ajouter des zeros devant le nombre et le convertir en texte
    Par SERGE6280 dans le forum Excel
    Réponses: 2
    Dernier message: 03/04/2013, 20h52
  4. Réponses: 3
    Dernier message: 24/10/2012, 15h02
  5. convertir en Texte mais dans sa forme entière un nombre long
    Par deca2 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 19/05/2010, 14h14

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