C++中读写txt文件并分离字符
2017-03-13 11:30
330 查看
在实际工程中,经常遇到需要读取txt文件,txt文件中存的是一些小数或者整型数据,在C++中,可以利用string类和ifstream库文件对txt进行的读取,不过读回的数据经常是以字符串的形式返回,一般是txt的一行为一个字符串返回。那么如何从字符串中分离出整数或者是小数就涉及到字符串的分割问题,下面就该问题进行总结。
一、C++中txt文件的读取
需要读取的txt文件如下:
代码如下:
#include<iostream>
#include<string>
#include<fstream>
using namespace std;
int main()
{
string s; //每次读取一行txt文件返回的字符串
//读取一txt文件
ifstream infile1;
infile1.open("1.txt");
while(getline(infile1, s))
{
cout << s << endl;
}
infile1.close(); //关闭文件
cin.get();
return 0;
}
执行结果如下:
注意:
(1)函数getline是一行一行读取txt文件,读回的结果以字符串的形式存储在s中,要读回具体的数据必须对字符串进行分离。
(2)打开txt必须用到fstream库中的ifstream类和其open和close成员函数。
(3)文件读取后一定要记得关闭文件,即调用close函数
二、字符串的分离
1读取的txt中只有整形的情况(要读回的txt文件如上图中所示)
代码如下:
#include<iostream>
#include<string>
#include<fstream>
using namespace std;
//如果字符串中都是整数
void stringTOnum1(string s, int* pdata)
{
bool temp=false; //读取一个数据标志位
int data=0; //分离的一个数据
int m=0; //数组索引值
for(int i=0;i<s.length();i++)
{
while((s[i]>='0')&&(s[i]<='9')) //当前字符是数据,并一直读后面的数据,只要遇到不是数字为止
{
temp=true; //读数据标志位置位
data*=10;
data+=(s[i]-'0'); //字符在系统以ASCII码存储,要得到其实际值必须减去‘0’的ASCII值
i++;
}
//刚读取了数据
if(temp) //判断是否完全读取一个数据
{
pdata[m]=data; //赋值
m++;
data=0;
temp=false; //标志位复位
}
}
}
int main()
{
int* pdata =new int[5];
string s;
//读取第一个txt文件
ifstream infile1;
infile1.open("1.txt");
while(getline(infile1, s))
{
stringTOnum1(s, pdata);
for(int i=0;i<5;i++)
cout << pdata[i] << " ";
cout << endl;
}
infile1.close();
cin.get();
return 0;
}
执行的结果如下:
顺利地读取了每行数据并分离出了整型数据保存在了数组中。
注意:
(1)字符在系统中以其ASCII码存储,对于数字字符要得到其实际的值,必须减去‘0’字符的ASCII码,之后的ASCII码就与数字字符的数据一致。
(2)基本思想:当遇到一个字符是数据后,不停的循环读后面的字符,直到遇到不是数字字符为止。
2读取的txt中有小数的情况
读回的txt如下图所示:
分离字符的函数如下:
//如果字符串中有小数
void stringTOnum2(string s, double* pdata)
{
bool temp=false;
int ndata=0; //整数部分
double fdata=0; //小数部分
int n=0; //小数部分的位数
int m=0;
for(int i=0;i<s.length();i++)
{
while((s[i]>='0')&&(s[i]<='9')||(s[i]=='.')) //当前字符是数据或者是小数点
{
temp=true;
if(s[i]=='.') //遇到了小数点
{
//不停的读取后面的小数
i++; //小数后的下一位
while((s[i]>='0')&&(s[i]<='9'))
{
n--;
fdata += (pow(10, n)*(s[i]-'0'));
i++;
}
}
//没有遇到小数点
else
{
ndata*=10;
ndata+=(s[i]-'0');
i++;
}
}
//刚读取了数据
if(temp)
{
pdata[m]=ndata+fdata;
m++;
ndata=0;
fdata=0;
n=0;
temp=false;
}
}
}
运行结果如下:
基本思想:在原先的基础上不仅要判断是否遇到了数字字符还需要判断是都遇到了小数点‘.’字符,如果遇到小数点字符,将后面的数据循环读取直到遇到不是数字字符为止。但是需要将其存为小数,有移位。
一、C++中txt文件的读取
需要读取的txt文件如下:
代码如下:
#include<iostream>
#include<string>
#include<fstream>
using namespace std;
int main()
{
string s; //每次读取一行txt文件返回的字符串
//读取一txt文件
ifstream infile1;
infile1.open("1.txt");
while(getline(infile1, s))
{
cout << s << endl;
}
infile1.close(); //关闭文件
cin.get();
return 0;
}
执行结果如下:
注意:
(1)函数getline是一行一行读取txt文件,读回的结果以字符串的形式存储在s中,要读回具体的数据必须对字符串进行分离。
(2)打开txt必须用到fstream库中的ifstream类和其open和close成员函数。
(3)文件读取后一定要记得关闭文件,即调用close函数
二、字符串的分离
1读取的txt中只有整形的情况(要读回的txt文件如上图中所示)
代码如下:
#include<iostream>
#include<string>
#include<fstream>
using namespace std;
//如果字符串中都是整数
void stringTOnum1(string s, int* pdata)
{
bool temp=false; //读取一个数据标志位
int data=0; //分离的一个数据
int m=0; //数组索引值
for(int i=0;i<s.length();i++)
{
while((s[i]>='0')&&(s[i]<='9')) //当前字符是数据,并一直读后面的数据,只要遇到不是数字为止
{
temp=true; //读数据标志位置位
data*=10;
data+=(s[i]-'0'); //字符在系统以ASCII码存储,要得到其实际值必须减去‘0’的ASCII值
i++;
}
//刚读取了数据
if(temp) //判断是否完全读取一个数据
{
pdata[m]=data; //赋值
m++;
data=0;
temp=false; //标志位复位
}
}
}
int main()
{
int* pdata =new int[5];
string s;
//读取第一个txt文件
ifstream infile1;
infile1.open("1.txt");
while(getline(infile1, s))
{
stringTOnum1(s, pdata);
for(int i=0;i<5;i++)
cout << pdata[i] << " ";
cout << endl;
}
infile1.close();
cin.get();
return 0;
}
执行的结果如下:
顺利地读取了每行数据并分离出了整型数据保存在了数组中。
注意:
(1)字符在系统中以其ASCII码存储,对于数字字符要得到其实际的值,必须减去‘0’字符的ASCII码,之后的ASCII码就与数字字符的数据一致。
(2)基本思想:当遇到一个字符是数据后,不停的循环读后面的字符,直到遇到不是数字字符为止。
2读取的txt中有小数的情况
读回的txt如下图所示:
分离字符的函数如下:
//如果字符串中有小数
void stringTOnum2(string s, double* pdata)
{
bool temp=false;
int ndata=0; //整数部分
double fdata=0; //小数部分
int n=0; //小数部分的位数
int m=0;
for(int i=0;i<s.length();i++)
{
while((s[i]>='0')&&(s[i]<='9')||(s[i]=='.')) //当前字符是数据或者是小数点
{
temp=true;
if(s[i]=='.') //遇到了小数点
{
//不停的读取后面的小数
i++; //小数后的下一位
while((s[i]>='0')&&(s[i]<='9'))
{
n--;
fdata += (pow(10, n)*(s[i]-'0'));
i++;
}
}
//没有遇到小数点
else
{
ndata*=10;
ndata+=(s[i]-'0');
i++;
}
}
//刚读取了数据
if(temp)
{
pdata[m]=ndata+fdata;
m++;
ndata=0;
fdata=0;
n=0;
temp=false;
}
}
}
运行结果如下:
基本思想:在原先的基础上不仅要判断是否遇到了数字字符还需要判断是都遇到了小数点‘.’字符,如果遇到小数点字符,将后面的数据循环读取直到遇到不是数字字符为止。但是需要将其存为小数,有移位。
相关文章推荐
- C++中读写txt文件并分离字符的方法
- Unicode(UTF16)文件读写终极方案---用C++标准的字节流读取,转化为宽字符(wchar_t),再以字节流写入
- C++文件读写操作(一) 逐字符读取文件
- VC读写txt文件时提示unrecognized character escape sequence(无法识别的字符转移序列)
- C++创建txt文件并在文件内写上字符
- Linux下运用C/C++实现txt文件的读写
- C++自动创建命名的txt文件以及读写txt文件
- C++读写txt文件方式以及基于opencv的Mat数据类型读写txt文件
- C++读写txt文件
- C++文件读写操作(将字幕写入txt文件文本)
- C++读写txt文件(基本操作1)
- C++读写txt文件
- C++ 文件读写 字符输出 字符串输出
- C++ txt文件插入字符时,未换行问题
- C++读写文件,处理UTF8文件,处理GBK中文字符
- C++实现txt文件读到另一个txt文件,并替代其中默写特定字符
- Unicode(UTF16)文件读写终极方案---用C++标准的字节流读取,转化为宽字符(wchar_t),再以字节流写入
- C++中对txt文件的读写操作
- C++ 读写txt文件
- C++读写txt文件