C 语言读写中文出现乱码,原因竟然是这个,解决方法更是让人意外 |
您所在的位置:网站首页 › fscanf读取汉字 › C 语言读写中文出现乱码,原因竟然是这个,解决方法更是让人意外 |
使用 fopen 打开一个utf-8的txt文件,然后用fscanf读取字符串,输出发现是乱码,显示的是用ANSI编码的对应字符
后来我怀疑文件编码不是fopen决定的,于是我注释掉了fwrite函数,然后惊讶地发现创建的txt是utf-8编码的
因此我认为,读取UTF8文件却得到ANSI编码的字符串是fscanf fwrite这些函数导致的,那么要如何正确的读取中文呢? 这个问题一直困扰了我很久,我试着把文件输出函数换成fputs。。 结果!!!他输出成功了!!!!! 但是读取之后在文本窗口输出时,还是ANSI编码,
至于这些函数的数据编码方式之类的原理,我一直找了好久也没找到 如果有大佬明白原因的话,希望可以不吝赐教 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |