c++ txt文件的读写及乱码问题解决

原创 2015年11月19日 17:36:35

在编程中,我们经常需要对txt文件进行读写操作,有时候由于编解码问题,txt读写会出现乱码问题。下面介绍一种基于ofstream和ifstream的txt文件读写方法,并介绍txt文件读写的乱码解决方案。

1.txt文件写入

#include <fstream>
#include <iostream>
using namespace std;

int main()
{   
    ofstream outfile("1.txt",ios::ate);   //打开文件,设置写入方式为覆盖写入

    if(!outfile)
    {
        cout<<"txt文件打开失败!"<<endl;
        exit(0);
    }

    outfile<<"写入txt文件示例.\n";
    outfile<<"成功写入.\n";

    outfile.close();
}

txt里面的写入内容如下:
这里写图片描述

成功写入。

2.txt文件读出

对上面读入内容的txt进行读出操作,代码如下:

#include <fstream>
#include <iostream>
using namespace std;

int main()
{   
    char txt[100];
    ifstream infile;
    infile.open("1.txt");

    if(!infile.is_open())
    {
        cout<<"txt文件打开失败"<<endl;
        exit(0);
    }

    while(!infile.eof())
    {       
        infile.getline(txt,100);
        cout<<txt<<endl;
    }

    infile.close();
    getchar();
}

读出结果为:
这里写图片描述
读出结果正确。

3.txt读写乱码问题

有时候由于txt文件编码问题的不同,会导致读写的时候出现乱码,通常的txt编码方式有:
这里写图片描述
上面默认的编码方式为ANSI,如果我们现在将它另存为1.txt,但编码格式变为UTF-8,那么读出结果会变成:
这里写图片描述
发现结果完全错误,这时候我们需要编解码转换,具体代码如下:

#include <fstream>
#include <iostream>
#include <Windows.h>
#include <string>
using namespace std;

string UTF8ToGB(const char* str)
{
     string result;
     WCHAR *strSrc;
     LPSTR szRes;

     //获得临时变量的大小
     int i = MultiByteToWideChar(CP_UTF8, 0, str, -1, NULL, 0);
     strSrc = new WCHAR[i+1];
     MultiByteToWideChar(CP_UTF8, 0, str, -1, strSrc, i);

     //获得临时变量的大小
     i = WideCharToMultiByte(CP_ACP, 0, strSrc, -1, NULL, 0, NULL, NULL);
     szRes = new CHAR[i+1];
     WideCharToMultiByte(CP_ACP, 0, strSrc, -1, szRes, i, NULL, NULL);

     result = szRes;
     delete []strSrc;
     delete []szRes;

     return result;
}

int main()
{   
    char txt[100];
    string msg;
    ifstream infile;
    infile.open("2.txt");

    if(!infile.is_open())
    {
        cout<<""<<endl;
        exit(0);
    }

    while(!infile.eof())
    {       
        infile.getline(txt,100);
        msg=UTF8ToGB(txt);
        cout<<msg<<endl;

    }

    infile.close();
    getchar();
}

将读出结果进行上述转换,发现结果又正确了。

相关文章推荐

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

C++读写汉字,C++处理中文字符

C++对多语言文本字符的支持,通过宽字符来解决。 只要将输入输出设备绑定到一个本地的locale对象上即可。locale currentlocale("chs");表示中国 其处理方法与原来的单字节字...

C++ 读取中文文本 。。。。

使用Windows API处理字符格式转换 [html] view plaincopy std::string ToUTF8(const wchar...

C++ 实现txt文件的读取

最近临时接到项目,加紧学习了一下C++,只是简单的文件的读取就弄了好久的说~~ 现在特意分享一下,希望对小伙伴们会有帮助喔~~ 1. 实现txt文件的读入并重写入另外一个txt文件中~ #inclu...

解决读取文件乱码问题

一般在windows上的txt文本文件要么以ANSI编码要么以Unicode编码,而用C ,C++,MFC编写的程序一般人只会处理一种编码格式的文本,因为不懂怎么判断读取的文件是以哪种编码格式存储的。...

fstream类读取UTF-8、Unicode和ANSI文本文档乱码问题的解决方案

原文链接:https://my.oschina.net/duluo180/blog/17457 1、解决UTF-8类型的文本文档中文乱码读取(思路:将UTF-8转成Unicode然后再转ANSI)...

一行一行的读取txt中文文本(解决乱码问题)

最近用MFC编Bayes文本分类器,需要将停用词从txt文件中依次读出来(每行一个词),用其本身的CStdioFile类的ReadString函数虽然可以一行一行读入文本,但到程序中就成了乱码...
  • Pc620
  • Pc620
  • 2011年04月11日 15:53
  • 6449

ifstream读取文件失败和乱码问题

ifstream读取文件失败往往是由于路径中包含中文字符而造成的,因为默认的ifstream对象无法识别出中文,从而导致路径解析乱码,无法找到文件而失败。      原理介绍:每个ifstrea...
  • pud_zha
  • pud_zha
  • 2014年02月28日 09:41
  • 2807

c++读取utf8等不同编码文件

今天写程序的时候遇到文件打开乱码的情况,我用notepad++打开发现是utf8编码的,后来上网查了一下,utf8是变长的,一般情况下文件开头有个BOM(Byte Order Mark)作为标识,一般...

获取txt文本文档的编码类型(c++,c#)

文件的字符集在Windows下有两种,一种是ANSI,一种Unicode。 对于Unicode,Windows支持了它的三种编码方式,一种是小尾编码(Unicode),一种是大尾编码(BigEndi...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:c++ txt文件的读写及乱码问题解决
举报原因:
原因补充:

(最多只允许输入30个字)