建议使用如下方法:
使用adobe acrobat XI pro软件打开图片文件。然后另存为Word文件。软件会自动把图片文件识别为可以编辑的文字。当然,里面会出现OCR识别错误,需要修改错误的文字。
打开Word文件,使用繁简转换功能,把繁体文字转换为简体文字。
请参照下面方法,把 CFile类 改成 FILE*。 写字符串改成写文件流。注意,汉字在utf8中占3个字节。
// unicode to ansi
void CConvertDlg::OnBnClickedButtonUnicodeToAnsi()
{
// unicode to ansi
wchar_t* wszString = L"abcd1234你我他"
//预转换,得到所需空间的大小,这次用的函数和上面名字相反
int ansiLen = ::WideCharToMultiByte(CP_ACP, NULL, wszString, wcslen(wszString), NULL, 0, NULL, NULL)
//同上,分配空间要给'\0'留个空间
char* szAnsi = new char[ansiLen + 1]
//转换
//unicode版对应的strlen是wcslen
::WideCharToMultiByte(CP_ACP, NULL, wszString, wcslen(wszString), szAnsi, ansiLen, NULL, NULL)
//最后加上'\0'
szAnsi[ansiLen] = '\0'
//Ansi版的MessageBox API
::MessageBoxA(GetSafeHwnd(), szAnsi, szAnsi, MB_OK)
//接下来写入文本
//写文本文件,ANSI文件没有BOM
CFile cFile
cFile.Open(_T("1.txt"), CFile::modeWrite | CFile::modeCreate)
//文件开头
cFile.SeekToBegin()
//写入内容
cFile.Write(szAnsi, ansiLen * sizeof(char))
cFile.Flush()
cFile.Close()
delete[] szAnsi
szAnsi =NULL
//方法2
//和上面一样有另一种方法
setlocale(LC_CTYPE, "chs")
char szStr[100]
//注意下面是大写,在ansi中,代表后面是unicode字符串
//sprintf
sprintf(szStr, "%S", wszString)
::MessageBoxA(GetSafeHwnd(), szStr, szStr, MB_OK)
}
// UTF8转UNICODE
void CConvertDlg::OnBnClickedButtonU8ToUnicode()
{
//UTF8 to Unicode
//由于中文直接复制过来会成乱码,编译器有时会报错,故采用16进制形式
char* szU8 = "abcd1234\xe4\xbd\xa0\xe6\x88\x91\xe4\xbb\x96\x00"
//预转换,得到所需空间的大小
int wcsLen = ::MultiByteToWideChar(CP_UTF8, NULL, szU8, strlen(szU8), NULL, 0)
//分配空间要给'\0'留个空间,MultiByteToWideChar不会给'\0'空间
wchar_t* wszString = new wchar_t[wcsLen + 1]
//转换
::MultiByteToWideChar(CP_UTF8, NULL, szU8, strlen(szU8), wszString, wcsLen)
//最后加上'\0'
wszString[wcsLen] = '\0'
//unicode版的MessageBox API
::MessageBoxW(GetSafeHwnd(), wszString, wszString, MB_OK)
//写文本同ansi to unicode
}
欢迎分享,转载请注明来源:夏雨云
评论列表(0条)