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 :

Etrange "espace vide" (ASCII 63) [Toutes versions]


Sujet :

Macros et VBA Excel

  1. #1
    FMJ
    FMJ est déconnecté
    Membre éclairé
    Profil pro
    tutu
    Inscrit en
    Octobre 2003
    Messages
    417
    Détails du profil
    Informations personnelles :
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : tutu

    Informations forums :
    Inscription : Octobre 2003
    Messages : 417
    Par défaut Etrange "espace vide" (ASCII 63)
    Bonjour,

    J'ai souhaité faire une macro afin de transformer un tableau Excel exporté d'une application, dont les données sont de la forme texte "12 867,20 €" en dur (i.e. ce n'est pas une mise en forme de style Excel).
    Pour obtenir des chiffres et non du texte, il a donc fallu remplacer les espaces par rien, les virgules par un point et les € par rien. Avec SUBSTITUTE ou REPLACE.
    Jusqu'à là, pas de pb, sauf que cela ne marchait pas avec l'espace....
    Après investigation, il est apparu que cet espace ne correspondait pas au caractère ASCII 32 mais au 63, c'est à dire "?". Cf illustration ci-dessous. Le première ligne est un copier/coller de la donnée importée. Pour les deux suivantes, j'ai écrit un espace vide " ", puis "?". Pour ce dernier on retrouve bien le même code ASCII.

    Nom : EXCEL_8jGl5gG82t.png
Affichages : 385
Taille : 3,1 Ko


    Mais, d'une part même en utilisant dans le code : REPLACE ou SUBSTITUTE avec "?" ou "~?" ou même en utilisant CHAR(63), impossible de remplacer cet espace.

    Le plus étrange, c'est que quand je regarde ce fichier Excel avec Notepad++ qui affiche les caractères spéciaux, je vois bien "12 867" et non "12?867" ou autre chose.

    Si vous auriez une idée sur la chose, je serai preneur. Merci

  2. #2
    Membre chevronné
    Homme Profil pro
    Responsable d'un système d'information métier
    Inscrit en
    Janvier 2007
    Messages
    227
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Responsable d'un système d'information métier
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 227
    Par défaut
    Bonjour,

    une fois viré le "€", ta chaine contenant des chiffres, as-tu essayé =CNUM( ...

  3. #3
    Membre chevronné
    Homme Profil pro
    Responsable d'un système d'information métier
    Inscrit en
    Janvier 2007
    Messages
    227
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Responsable d'un système d'information métier
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 227
    Par défaut
    tu peux aussi regarder le post du 05/04 à 14h04 de Sharkly77fr

  4. #4
    Expert confirmé
    Avatar de jurassic pork
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Décembre 2008
    Messages
    4 178
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2008
    Messages : 4 178
    Par défaut
    Hello,
    c'est peut-être le "zero-width space" caractère unicode . Pour l'enlever tu peux essayer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Replace(cel.Value, ChrW(8203), "")
    [EDIT] ou 8239 :
    decimal 8203 U+200B ZERO WIDTH SPACE
    decimal 8239 U+202F NARROW NO-BREAK SPACE
    Ami calmant, J.P

  5. #5
    FMJ
    FMJ est déconnecté
    Membre éclairé
    Profil pro
    tutu
    Inscrit en
    Octobre 2003
    Messages
    417
    Détails du profil
    Informations personnelles :
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : tutu

    Informations forums :
    Inscription : Octobre 2003
    Messages : 417
    Par défaut
    Bonjour,

    Oui c'est bien cela, c'était de l'UNICODE et non de l'ASCIII. ChrW(8203) fait le job !
    Je remets le lien du post décrivant la solution : https://www.developpez.net/forums/d2...lement-espace/

    Merci à vous !

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

Discussions similaires

  1. Construire une chaine avec plusieurs espaces vides
    Par imane_bennouna dans le forum Langage
    Réponses: 10
    Dernier message: 04/08/2006, 09h29
  2. Ne pas afficher d'espace vide lorsqu'on masque un <div>
    Par guybrush007 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 03/08/2006, 11h02
  3. [CSS] Souligner espace vide ?
    Par cristolb dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 13/01/2006, 23h36
  4. [String] comment virer tous les espaces vides ?
    Par Alec6 dans le forum Langage
    Réponses: 6
    Dernier message: 26/07/2004, 14h27
  5. Combler l'espace vide entre deux id
    Par Marshall_Mathers dans le forum Requêtes
    Réponses: 5
    Dernier message: 01/07/2004, 11h33

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