C++中怎样从文件中读取一个float型的数据
txt中的数据类型大概如下:1500.55600.552500.56600.763501.12700.49。。。。。。。。。。。。第一列为拍数,第二列和第三列为每个周期需...
txt中的数据类型大概如下:
1 500.55 600.55
2 500.56 600.76
3 501.12 700.49
。。。。。。。。。。。。
第一列为拍数,第二列和第三列为每个周期需要读取的数据,怎样才能将第二列和第三列的数据读取出来 展开
1 500.55 600.55
2 500.56 600.76
3 501.12 700.49
。。。。。。。。。。。。
第一列为拍数,第二列和第三列为每个周期需要读取的数据,怎样才能将第二列和第三列的数据读取出来 展开
3个回答
展开全部
你是不是在某个QQ群里面问题过这个啊 - -
好吧,流入这样的函数就可以读出一行
int main()
{
ifstream i("1.txt");
int a;
double b,c;
i>>a>>b>>c;
cout<<a<<b<<c;
return 0;
}
上程序假设1.txt文件的内容为
1 500.55 600.55
2 500.56 600.76
3 501.12 700.49
因为标准输入流会忽略空格和换行,然后用空格和换行分割字符
这是读出一行的,那读出N行的呢?把上面程序循环n次就好了⋯⋯
好吧,流入这样的函数就可以读出一行
int main()
{
ifstream i("1.txt");
int a;
double b,c;
i>>a>>b>>c;
cout<<a<<b<<c;
return 0;
}
上程序假设1.txt文件的内容为
1 500.55 600.55
2 500.56 600.76
3 501.12 700.49
因为标准输入流会忽略空格和换行,然后用空格和换行分割字符
这是读出一行的,那读出N行的呢?把上面程序循环n次就好了⋯⋯
展开全部
//C语言中从文件中读取双精度浮点数
#include"stdio.h"
#include"string.h"
main()
{
int i;
FILE *fp;
char filename[100];
double data[20000][2];
printf("Iput filename:");
scanf("%s",filename);
if((fp=fopen(filename,"r"))==NULL)
{
printf("Cannot open this file\n");
exit(0);
}
for(i=0;i<20000;i++)
{
fscanf(fp,"%lf %lf",&data[i][0],&data[i][1]);
}
fclose(fp);
return 0;
}
注意:double双精度型数值的输入必须用%lf,而它的输出则和float单精度型数值一样用%f,%e均可。同时注意fscanf()和scanf()类似在输入数据的时候不能指定数据的精度。fscanf()可以自动判断回车,所以在格式符后面添加'\n'也是多余的。而且对本题,"%lf%lf"之间加不加空格都是一样的,fscanf()遇到空格会自动判断第一个数据读入完成,接下来的就是第二个数据。当然如果是数值加字符,那么空格就必不可少要和文件中严格对应了。 //C++语言中从文件中读取双精度浮点数 #include <iostream> #include <fstream> using namespace std; void main() {
int i;
FILE *fp;
ifstream infile(pChar,ios::in);//已输入方式打开文件 //检验文件打开是否成功 if(!infile) {
cerr<<"open error!"<<endl;
exit(1);
}
#include"stdio.h"
#include"string.h"
main()
{
int i;
FILE *fp;
char filename[100];
double data[20000][2];
printf("Iput filename:");
scanf("%s",filename);
if((fp=fopen(filename,"r"))==NULL)
{
printf("Cannot open this file\n");
exit(0);
}
for(i=0;i<20000;i++)
{
fscanf(fp,"%lf %lf",&data[i][0],&data[i][1]);
}
fclose(fp);
return 0;
}
注意:double双精度型数值的输入必须用%lf,而它的输出则和float单精度型数值一样用%f,%e均可。同时注意fscanf()和scanf()类似在输入数据的时候不能指定数据的精度。fscanf()可以自动判断回车,所以在格式符后面添加'\n'也是多余的。而且对本题,"%lf%lf"之间加不加空格都是一样的,fscanf()遇到空格会自动判断第一个数据读入完成,接下来的就是第二个数据。当然如果是数值加字符,那么空格就必不可少要和文件中严格对应了。 //C++语言中从文件中读取双精度浮点数 #include <iostream> #include <fstream> using namespace std; void main() {
int i;
FILE *fp;
ifstream infile(pChar,ios::in);//已输入方式打开文件 //检验文件打开是否成功 if(!infile) {
cerr<<"open error!"<<endl;
exit(1);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include <iostream.h>
#include <fstream.h>
void main()
{
int i;
float a[15];
float b1[5];
float b2[5];
ifstream infile("t.txt",ios::in);
for(i=0;i<15;i++)
{
infile>>a[i];
}
infile.close();
for(i=0;i<5;i++)
{
b1[i]=a[3*i+1];
b2[i]=a[3*i+2];
}
for(i=0;i<5;i++)
{
cout<<b1[i]<<" "<<b2[i]<<endl;
}
}
建立一个t.txt,放在你的工程文件下
数据为
1 500.55 600.55
2 500.56 600.76
3 501.12 700.49
4 502.56 601.76
5 503.12 701.49
#include <fstream.h>
void main()
{
int i;
float a[15];
float b1[5];
float b2[5];
ifstream infile("t.txt",ios::in);
for(i=0;i<15;i++)
{
infile>>a[i];
}
infile.close();
for(i=0;i<5;i++)
{
b1[i]=a[3*i+1];
b2[i]=a[3*i+2];
}
for(i=0;i<5;i++)
{
cout<<b1[i]<<" "<<b2[i]<<endl;
}
}
建立一个t.txt,放在你的工程文件下
数据为
1 500.55 600.55
2 500.56 600.76
3 501.12 700.49
4 502.56 601.76
5 503.12 701.49
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询