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

C Discussion :

probléme wchar unicode


Sujet :

C

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 17
    Par défaut probléme wchar unicode
    bonjour,

    Je voudrai savoir comment faire pour spécifier que le type wchar_t contient un caractère unicode.fwscanf ecris dans un wchar faudrait t'il spécifier unicode pour avoir les bons résultats?

  2. #2
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    ??

    En extrapolant à partir du peu de mots compréhensibles de ton message, je pense que ton problème vient du fait que les fonctions que tu utilises pour lire dans le flux sont unicode, mais que ton environnement C++ considère le flux comme ne l'étant pas.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    217
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 217
    Par défaut
    Comme ça ça marche.

  4. #4
    Expert confirmé
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Par défaut
    Citation Envoyé par titi2 Voir le message
    bonjour,

    Je voudrai savoir comment faire pour spécifier que le type wchar_t contient un caractère unicode.
    En C standard ? Impossible. Par contre sous Windows le type wchar_t est utilisé pour représenter des caractères unicode.
    Citation Envoyé par titi2
    fwscanf ecris dans un wchar faudrait t'il spécifier unicode pour avoir les bons résultats?
    fwscanf requiert un argument de type wchar_t * à la place du char * de fscanf. Il n'y a rien à spécifier de plus pour qu'il en soit ainsi. Si ce que tu cherches c'est comment faire pour que _ftscanf (Microsft) corresponde à fwscanf, il faut définir la macro UNICODE (sous Visual C++ 2005 et plus écents UNICODE est déjà défini par défaut).

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 17
    Par défaut
    bonjour,
    Merci pour vos réponses
    le probleme comme Médinoc l'a dit c'est que l'environnement C ne considére pas Wchar comme étant unicode? quelqu'un aurait une solution?

  6. #6
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Par défaut
    les caractères larges (wchar_t) en C ont été crées pour pouvoir stocker tous les caractères possibles (plsu ou moins...)

    La norme laisse à l'implémentation le choix de la taille de stockage et donc le nombre de caractères possibles.

    Selon les implémentations actuelles, cela peut être 1, 2,4 bytes.

    Maintenant, la notion d'unicode porte sur l'encodage de ces caractères (codepoints, surrogates, ...). Il n'y à pas un Unicode mais des encodages Unicodes : UTF7, UTF8, UTF16 (fixe ou variables), UTF32, ....

    les chaines de caractères larges (wchar_t *) permettent de stocker des chaines unicodes. C'est tout.

    L'interprétation du contenu dépend d'un encodage donné.

    Par exemple :
    • Windows gère Unicode par de l'UTF16 (variables avec surrogates) et wchar_t est sur 2 bytes (unsigned short)
    • Linux gère Unicode avec UTF32 et wchar_t est sur 4 bytes (unsigned long)

    Que veux tu réellement faire ? ton post n'est pas clair.
    Vincent Rogier.

    Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

    Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

    OCILIB (C Driver for Oracle)

    Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle

  7. #7
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    C'est pas une question de wchar, c'est une question de savoir ton problème.

    C'est un problème quand tu lis/écris un fichier, ou c'est pour les chaînes littérales?
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  8. #8
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 17
    Par défaut
    je lis un fichier utf-8 puis j'ecris dans un fichier avec les fonctions wchar ca marche par contre quand je veux afficher le code des caractères du wchar je me rend compte que c'est pas les meme que ceux des caractères unicode dans mon fichier.Donc je conclus que le stockage en mémoire ne se fait pas bien.

  9. #9
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Y'a pas grand-chose pour lire de l'UTF-8.

    Si tu es sous un Linux entièrement UTF-8, on peut espérer que les données soient correctement converties en wchar_t en lecture.
    Sous Windows, il n'y a rien de prévu "de base", sauf dans les versions récentes (>= VS2005) de la C Run-Time library, qui permettent de lire des fichiers en UTF-8 ou UTF-16.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. Problème compilation UNICODE -> ASCII
    Par Kalite dans le forum Qt
    Réponses: 2
    Dernier message: 01/12/2008, 15h58
  2. Problème avec Unicode
    Par pdgnr dans le forum Windows Forms
    Réponses: 6
    Dernier message: 07/01/2008, 23h06
  3. Migration SQL 2000 vers 2005 et problème d'Unicode
    Par Micht dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 22/03/2007, 09h34
  4. [XHTML] Problème de Unicode Byte-Order Mark (BOM) in UTF-8 (?)
    Par gb-ch dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 13/02/2007, 02h01
  5. [CR(10)]Problème avec unicode (japonais)
    Par speed034 dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 26/05/2005, 09h55

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