C++ 读写utf-8文件

转载自:https://blog.csdn.net/sdscscs22/article/details/53895416

UTF-8

UTF-8(8-bit Unicode Transformation Format)是一种针对Unicode的可变长度字符编码,又称万国码。由Ken Thompson于1992年创建。现在已经标准化为RFC 3629。UTF-8用1到4个字节编码Unicode字符。用在网页上可以统一页面显示中文简体繁体及其它语言(如英文,日文,韩文)。

C++编码时有时会用到修改utf-8文件,c++11新特性里给了新的解决办法。

包含头文件 #include <codecvt>

 
  1. #include <fstream>

  2. #include <string>

  3. #include <codecvt>

  4. #include <iostream>

  5.  
  6. using namespace std;

  7.  
  8. int main(int argc, char *argv[])

  9. {

  10. std::wstring str = L"123,abc:我是谁!";

  11.  
  12. std::wstring_convert<std::codecvt_utf8<wchar_t>> conv;

  13.  
  14. std::string narrowStr = conv.to_bytes(str);

  15. {

  16. std::ofstream ofs("d:\\test.txt"); //文件是utf8编码

  17. ofs << narrowStr;

  18. }

  19.  
  20. std::ifstream ifs(L"d:\\test.txt");

  21. while (!ifs.eof())

  22. {

  23. string line;

  24. getline(ifs, line);

  25. wstring wb = conv.from_bytes(line);

  26. wcout.imbue(locale("chs")); //更改区域设置 只为控制台输出显示

  27. wcout << wb << endl;

  28. }

  29. }

猜你喜欢

转载自blog.csdn.net/cyem1/article/details/82670648