<p>今天写一段代码,读ply文件,因为我的ply点云文件长这样。
前面有一段是一些标识字段,比如是 ascii码,包含x,y, z,还有三个法向量什么的。
因为我只要14列以后的的x, y, z,相当于前面的我都不读入。 就需要一个从第n行以后开始读入数据的方式
从特定行开始读取
上笨办法
#include<iostream>
#include<fstream>
#include<istream>
#include<ostream>
#include<sstream>
#include<vector>
using namespace std;
int main()
{
ifstream in;
ofstream out("test_out.txt");
const char* filename = "fileRead_test.txt";
in.open(filename);
if (!in)
{
std::cerr << "File " << filename << " could not be opened" << std::endl;
return false;
}
string line;
for (int i = 0; i < 13; i++)
{
getline(in, line);
}
double x, y, z;
//错误示范,最后一行会读两遍
while (!in.eof())
{
in >> x >> y >> z;
getline(in, line);
// cout << line << endl;;
cout << x << " " << y << " " << z << endl;
}
//错误示范结束
in.close();
//system("pause");
return 0;
}
结果变成这样:
看到没最后一行结果读了两次,因为 getline()函数执行成功一次后,指针就会移动到那一行的末尾,但是来到文件末尾以后,虽然已经到文件末尾,但是为了防止越界,指针还是会停留在那里,所以会再读取一次
文件末尾读入两遍解决方案之–使用fail进行判断
循环读取文件的时候,要将fail和eof结合起来使用:在循环判断中使用fail,fail失败后再使用eof。 错误示范的代码段改为
while (!in.eof())
{
in >> x >> y >> z;
getline(in, line);
if (in.fail())
break;
// cout << line << endl;;
cout << x << " " << y << " " << z << endl;
}
结果是不是正确啦
<hr>
<ul class="pager">
<li class="previous">
<a href="/%E5%BE%AE%E5%88%86%E5%87%A0%E4%BD%95/2018/04/07/%E5%BE%AE%E5%88%86%E5%87%A0%E4%BD%95/" data-toggle="tooltip" data-placement="top" title="" data-original-title="微分几何">← Previous Post</a>
</li>
<li class="next">
<a href="/pcl%E4%B8%8E%E7%82%B9%E4%BA%91%E4%B8%87%E8%B1%A1/2018/07/11/PCL%E4%B8%ADply%E4%B8%8D%E6%94%AF%E6%8C%81double/" data-toggle="tooltip" data-placement="top" title="" data-original-title="PCL中ply不支持double">Next Post →</a>
</li>
</ul>
蚊子再小也是肉~