Преобразование wstring в строку, закодированную в UTF-8

мне нужно преобразовать между wstring и string. Я понял, что использование фасета codecvt должно помочь, но, похоже, это не работает для локали utf-8.

Моя идея состоит в том, что когда я читаю файл в кодировке utf-8 в символы, один utf-8 символ читается в два обычных символа (так работает utf-8). Я хотел бы создать эту строку utf-8 из представления wstring для библиотеки, которую я использую в своем коде.

Кто-нибудь знает, как это сделать?

Я уже пробовал это:

  locale mylocale("cs_CZ.utf-8");
  mbstate_t mystate;

  wstring mywstring = L"čřžýáí";

  const codecvt<wchar_t,char,mbstate_t>& myfacet =
    use_facet<codecvt<wchar_t,char,mbstate_t> >(mylocale);

  codecvt<wchar_t,char,mbstate_t>::result myresult;  

  size_t length = mywstring.length();
  char* pstr= new char [length+1];

  const wchar_t* pwc;
  char* pc;

  // translate characters:
  myresult = myfacet.out (mystate,
      mywstring.c_str(), mywstring.c_str()+length+1, pwc,
      pstr, pstr+length+1, pc);

  if ( myresult == codecvt<wchar_t,char,mbstate_t>::ok )
   cout << "Translation successful: " << pstr << endl;
  else cout << "failed" << endl;
  return 0;

, которое возвращает 'failed' для cs_CZ.utf-8 и корректно работает с локалью cs_CZ.iso8859-2.

17
задан skaffman 5 December 2010 в 13:03
поделиться