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

MFC Discussion :

conversion chaineISO8859-1,... en UTF-8


Sujet :

MFC

  1. #21
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 381
    Points : 41 582
    Points
    41 582
    Par défaut
    Eh bien, ça marche!
    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
    60
    61
    #define WIN32_LEAN_AND_MEAN
    #include <windows.h>
    #include <stdio.h>
    #include <stdlib.h>//pour system()
     
    int main(void)
    {
    char const sczCyrillique[] = "\xE5";
    char const sczGrec[] = "\xE5";
    UINT const uiCpCyrillique = 1251;
    UINT const uiCpGrec = 1253;
     
    WCHAR szBufferW[10] = L"";
    char szBufferOemCp850[10] = "";
     
    //Test avec le caractère cyrillique
    MultiByteToWideChar( uiCpCyrillique, 0, sczCyrillique, -1, szBufferW, 10);
    printf("Caractere cyrillique %u (0x%02X) en unicode : %u (0x%04X)\n",
     (unsigned char)sczCyrillique[0], (unsigned char)sczCyrillique[0],
     szBufferW[0], szBufferW[0]
     );
     
    //Test avec le caractère grec
    MultiByteToWideChar( uiCpGrec, 0, sczGrec, -1, szBufferW, 10);
    printf("Caractere grec %u (0x%02X) en unicode : %u (0x%04X)\n",
     (unsigned char)sczGrec[0], (unsigned char)sczGrec[0],
     szBufferW[0], szBufferW[0]
     );
     
    MessageBoxW(NULL, szBufferW, L"Caract\xE8re grec en unicode",
     MB_OK | MB_ICONINFORMATION);
     
    //Test en OEM (Codepage 850, qui ne contient pas le carac. grec)
    CharToOemBuffW(szBufferW, szBufferOemCp850, 10);
    printf("Caractere unicode %u (0x%04X) converti en OEM (CP-850) : %u (0x%02X)\n",
     szBufferW[0], szBufferW[0],
     (unsigned char)szBufferOemCp850[0], (unsigned char)szBufferOemCp850[0]
     );
    printf("Chaine unicode convertie en OEM (CP-850) : %s\n", szBufferOemCp850);
     
    //Test UTF-8
    	{
    	char szBufferUtf8[10] = "";
    	size_t tailleChnUtf8;
    	size_t i;
     
    	WideCharToMultiByte(CP_UTF8, 0, szBufferW, -1,
    	 szBufferUtf8, sizeof(szBufferUtf8), NULL, NULL);
     
    	//Ca marche a tous les coups,
    	//l'UTF-8 garantit qu'aucun octet d'un caratere n'est nul
    	tailleChnUtf8 = strlen(szBufferUtf8);
    	printf("Caractere grec converti en %u octets UTF-8:\n", tailleChnUtf8);
    	for(i = 0 ; i<tailleChnUtf8 ; i++)
    	    printf("%02X ", (unsigned char)szBufferUtf8[i]);
    	printf("\n");
    	}
     
    system("pause");
    return 0;
    }
    Et j'obtiens:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Caractere cyrillique 229 (0xE5) en unicode : 1077 (0x0435)
    Caractere grec 229 (0xE5) en unicode : 949 (0x03B5)
    Caractere unicode 949 (0x03B5) converti en OEM (CP-850) : 101 (0x65)
    Chaine unicode convertie en OEM (CP-850) : e
    Caractere grec converti en 2 octets UTF-8:
    CE B5
    Appuyez sur une touche pour continuer...
    Plus une belle MessageBoxW avec un magnifique epsilon grec.

    Où est le problème ?

  2. #22
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    731
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 731
    Points : 574
    Points
    574
    Par défaut
    Excuse moi Medinoc, j'ai réussi à le faire tourner hier soir, j'avais juste mes define de codepage qui avaient la même valeur, il m'a fallu deux heures avant de le voir (les joies du copy/paste).
    Merci

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. VBA : conversion fichier texte en UTF-8
    Par philou8 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 31/12/2009, 18h50
  2. Conversion du caractère & en UTF-8 ?
    Par astrofiles dans le forum Général Java
    Réponses: 5
    Dernier message: 05/01/2007, 16h40
  3. conversion iso-8859-1 => UTF-8 (unicode)
    Par pierru666 dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 30/05/2006, 22h17
  4. Conversion du charset cyrillique vers l'UTF-8
    Par pach dans le forum Oracle
    Réponses: 2
    Dernier message: 12/01/2006, 13h47
  5. Conversion vers UTF-8
    Par magnus2005 dans le forum Langage
    Réponses: 1
    Dernier message: 26/10/2005, 10h12

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