Maison > développement back-end > C++ > le corps du texte

Comment lire des fichiers Unicode (UTF-8) dans des chaînes wstrings sous Windows avec C 11 ?

Patricia Arquette
Libérer: 2024-11-06 07:26:02
original
911 Les gens l'ont consulté

How to Read Unicode (UTF-8) Files into wstrings on Windows with C  11?

Lecture de fichiers Unicode UTF-8 dans des chaînes Wstrings sous Windows

La lecture de fichiers Unicode (UTF-8) dans des chaînes Wstrings sous Windows peut être réalisé efficacement en utilisant la facette std::codecvt_utf8 de C 11.

Avec std::codecvt_utf8, la conversion entre les chaînes d'octets UTF-8 et les chaînes de caractères UCS2 ou UCS4 est simplifiée. Cette facette permet de lire et d'écrire des fichiers UTF-8, à la fois texte et binaires.

Pour exploiter la facette, créez un objet de paramètres régionaux qui encapsule les facettes définissant l'environnement localisé souhaité. Une fois l'objet locale créé, imprégnez-en votre tampon de flux.

Voici une implémentation utilisant l'imbuing :

#include <sstream>
#include <fstream>
#include <codecvt>

std::wstring readFile(const char* filename)
{
    std::wifstream wif(filename);
    wif.imbue(std::locale(std::locale::empty(), new std::codecvt_utf8<wchar_t>));
    std::wstringstream wss;
    wss << wif.rdbuf();
    return wss.str();
}
Copier après la connexion

Après avoir imprégné le tampon de flux, la lecture du fichier dans une wstring est simple :

std::wstring wstr = readFile("a.txt");
Copier après la connexion

Alternativement, définir les paramètres régionaux globaux C avant de travailler avec des flux de chaînes éliminera le besoin d'une imprégnation explicite :

std::locale::global(std::locale(std::locale::empty(), new std::codecvt_utf8<wchar_t>));
Copier après la connexion

Cela définit les paramètres régionaux globaux par défaut, ce qui automatiquement s'appliquer aux futurs tampons de flux.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!