9

我想使用 c++ 读取 csv 文件所以这是我的代码

 int main(){
 ifstream classFile("class.csv");
 vector<string> classData;

 while (getline(classFile, line,',')) // there is input overload classfile
        {
            classData.push_back(line);  

        }
}

这是我的问题:我的问题是当它读取每一行的最后一列时(因为它没有用逗号分隔)它读取最后一列数据和下一行数据的第一列,例如,如果我的数据像

className, classLocation, Professor c++, Library, John

然后它看起来像 className/classLocation/Professor c++/Library/John

无论如何,我可以将我的最后一列与下一行的第一列分开吗?谢谢,对不起,这令人困惑

4

3 回答 3

25

逐行读取文件:

std::string line;
while(std::getline(stream, line)) ...

将每一行传递给 istingstream 并读取字段:

std::istringstream s(line);
std::string field;
while (getline(s, field,',')) ...

免责声明:这是对 csv 文件的简化解析。

于 2013-11-12T18:02:35.107 回答
4

抱歉,我可以在这个线程中加入一些普通的 C 吗?

在那里阅读 csv 非常清楚:

#include <stdio.h>


int main()
{
  float f1, f2;

  FILE *fp;
  fp = fopen("file.csv", "r");

  while (fscanf(fp, "%g,%g\n", &f1, &f2) == 2)
    printf("%g\n", f1+f2);
}

毫无疑问,它应该在 C++ 工作的地方工作。

在那里,在 中while,我们检查 fscanf 找到了多少对象:fscanf(fp, "%g,%g\n", &f1, &f2) == 2-- fscanf 返回它找到的对象的数量。

我希望它可能对某人有所帮助。

(如果有人想查看有关fscanf和阅读文件的更多信息 - 留下一些评论。)

于 2014-07-08T16:19:58.590 回答
0

如果您有兴趣void在您的部分中调用一个函数main,请查看以下代码:

void readCSV(const string &strPath2Dataset)
{   
    ifstream csvFile;
    string strPathCSVFile = strPath2Dataset + "/test.csv";
    csvFile.open(strPathCSVFile.c_str());

    if (!csvFile.is_open())
    {
        cout << "Path Wrong!!!!" << endl;
        exit(EXIT_FAILURE);
    }

    vector<long double> timeStampIMU;
    vector<long double> gyro_X;
    vector<long double> gyro_Y;
    vector<long double> gyro_Z;

    vector<long double> acc_X;
    vector<long double> acc_Y;
    vector<long double> acc_Z;

    string line;
    vector <string> vec;
    getline(csvFile, line); // skip the 1st line

    while (getline(csvFile,line))
    {
        if (line.empty()) // skip empty lines:
        {
            //cout << "empty line!" << endl;
            continue;
        }

        istringstream iss(line);
        string lineStream;
        string::size_type sz;

        vector <long double> row;

        while (getline(iss, lineStream, ','))
        {  
            row.push_back(stold(lineStream,&sz)); // convert to double
        }

        timeStampIMU.push_back(row[0]);

        gyro_X.push_back(row[1]);
        gyro_Y.push_back(row[2]);
        gyro_Z.push_back(row[3]);

        acc_X.push_back(row[4]);
        acc_Y.push_back(row[5]);
        acc_Z.push_back(row[6]);
    }

    //cout << "size ts = " << timeStampIMU.size() << endl;
    for (size_t i = 0; i < timeStampIMU.size(); i++)
    {
        cout << "ts_imu = " << setprecision(12) << timeStampIMU[i] << endl;

        cout << "gx = " << setprecision(12) << gyro_X[i] << endl;
        cout << "gy = " << setprecision(12) << gyro_Y[i] << endl;
        cout << "gz = " << setprecision(12) << gyro_Z[i] << endl;

        cout << "ax = " << setprecision(12) << acc_X[i] << endl;
        cout << "ay = " << setprecision(12) << acc_Y[i] << endl;
        cout << "az = " << setprecision(12) << acc_Z[i] << endl;
        cout << "--------------------------------" << endl;
    }
}

我的.csv文件是 IMU 传感器提供的数据集,以逗号分隔:

TimeStamp, Gyro_X, Gyro_Y, Gyro_Z, Acc_X, Acc_Y, Acc_Z
于 2018-12-21T08:05:49.160 回答