VC下實現fopen支持中文的方法
來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊: 次
VC的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的長度不能靈活設置,讀者可根據自身需求進一步加以完善!
您可能感興趣的文章
- 01-10數據結構課程設計-用棧實現表達式求值的方法詳解
- 01-10使用OpenGL實現3D立體顯示的程序代碼
- 01-10求斐波那契(Fibonacci)數列通項的七種實現方法
- 01-10C語言 解決不用+、-、×、÷數字運算符做加法
- 01-10使用C++實現全排列算法的方法詳解
- 01-10用C++實現DBSCAN聚類算法
- 01-10深入全排列算法及其實現方法
- 01-10大數(高精度數)模板(分享)
- 01-10全排列算法的非遞歸實現與遞歸實現的方法(C++)
- 01-10用C語言實現單鏈表的各種操作(一)


閱讀排行
本欄相關
- 04-02c語言函數調用后清空內存 c語言調用
- 04-02func函數+在C語言 func函數在c語言中
- 04-02c語言的正則匹配函數 c語言正則表達
- 04-02c語言用函數寫分段 用c語言表示分段
- 04-02c語言中對數函數的表達式 c語言中對
- 04-02c語言編寫函數冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數 round c語言
- 04-02c語言分段函數怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數 c語言中怎
- 04-02c語言調用函數求fibo C語言調用函數求
隨機閱讀
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-11ajax實現頁面的局部加載
- 01-10C#中split用法實例總結
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05dedecms(織夢)副欄目數量限制代碼修改
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 04-02jquery與jsp,用jquery
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-10SublimeText編譯C開發(fā)環(huán)境設置