转自https://blog.csdn.net/relar/article/details/18954007
fopen的第一个参数是const char*,如何遇到中文文件名就麻烦了,如果中文是UTF8,我们可以用下列代码将其转换为UNICODE,然后用_wfopen函数打开文件。
上代码:
-
bool UTF8ToUnicode(const char* UTF8, wchar_t* strUnicode)
-
{
-
DWORD dwUnicodeLen; //转换后Unicode的长度
-
TCHAR *pwText; //保存Unicode的指针
-
// wchar_t* strUnicode; //返回值
-
//获得转换后的长度,并分配内存
-
dwUnicodeLen = MultiByteToWideChar(CP_UTF8,0,UTF8,-1,NULL,0);
-
pwText = new TCHAR[dwUnicodeLen];
-
if (!pwText)
-
{
-
return false;
-
}
-
//转为Unicode
-
MultiByteToWideChar(CP_UTF8,0,UTF8,-1,pwText,dwUnicodeLen);
-
//转为CString
-
wcscpy(strUnicode, pwText);
-
//清除内存
-
delete []pwText;
-
return true;
-
}
使用这个函数:
wchar_t strUnicode[260];
UTF8ToUnicode(streamName, strUnicode);
FILE* fid = _wfopen(strUnicode, L"rb");
// FILE* fid = fopen(streamName, "rb");//此为原来的方法,遇到中文不能正确打开
上述函数其实不够完善,参数strUnicode的长度不能灵活设置,有时间再完善。
strUnicode