4

我从 22 个不同语言的文件中分离出部分,并将它们做成 wstring 行,例如:

wstring wstr_line = L"\"IDS_TOAST_ECOON\",\"eco Mode is turned On.\",\"ecoモードをオンにしました。\",\"Režim eco je zapnutý.\",\"Økoindstillingen er aktiveret\"..."

我使用 wofstream 将 wstr_line 放入文件中,但该行在日语部分完成(\“ecoモードをオンにしました。\”)。如果我将wfout.imbue("chs");线路设置在捷克部分完成(\“Režim eco je zapnutý.\”)

如何正确将此行写入文件?

4

2 回答 2

0

尝试将其作为代码的第一行:

int main()
{
    std::cout.imbue(std::locale(""));

这会将应用程序的本地设置为机器支持的内容(对于宽字符串可能是 UTF-32)。不幸的是,对于程序员来说,默认的本地是“C”,而“C”本地的 codecvt 方面没有做任何有用的事情(可能会在不转换的情况下将宽包截断为单个字节)。

于 2012-07-30T04:44:09.630 回答
0

我已经用另一种策略解决了这个问题,output the lines in bytes. 使用下面的函数输出 wstring,无论它包含什么字符。

void output(ofstream &fout, vector<wstring> wline_list)
{
    void outputline(ofstream &, wstring);
  //pre output 0xFF and 0xFE to make the file encoding in UTF-16
    const BYTE PRE_LOW = 0xFF;
    const BYTE PRE_HIGH = 0xFE;
    fout << PRE_LOW << PRE_HIGH;
    for(vector<wstring>::size_type i(0); i<wline_list.size(); i++)
        outputline(fout, wline_list[i]);
}

void outputline(ofstream &fout, wstring line)
{
    void getByte(BYTE btchar[2], WORD wdChar);
    BYTE btChar[2] = {0,0};

    const BYTE CHANGE_LINE1_LOW = 0x0D;
    const BYTE CHANGE_LINE1_HIGH = 0x00;
    const BYTE CHANGE_LINE2_LOW = 0x0A;
    const BYTE CHANGE_LINE2_HIGH = 0x00;

    WORD wdChar(0);
    for(wstring::size_type i(0); i<line.length(); i++)
    {
        wdChar = line[i];
        getByte(btChar, wdChar);
        fout << btChar[0] << btChar[1];
    }
  //it needs this two chars to change line.
    fout << CHANGE_LINE1_LOW << CHANGE_LINE1_HIGH
        << CHANGE_LINE2_LOW << CHANGE_LINE2_HIGH;
}

void getByte(BYTE btchar[2], WORD wdChar)
{
    btchar[0] = wdChar % 0x0100;
    btchar[1] = wdChar / 0x0100;
}
于 2012-07-31T07:31:19.383 回答