在c++中从.csv读取文件

问题描述 投票:0回答:2

我正在编写一个从 .csv 文件获取输入的程序。程序运行,但问题是它只返回 .csv 文件的最后一行,并跳过所有其他 9 行。 它也不显示平均值和等级。请帮我找出我做错了什么。

教授非常具体地使用了我们迄今为止所学到的知识,即循环和函数。我只能使用循环和函数,因此不允许使用数组。

这是scores.csv 文件

#include <iostream>
#include <fstream>

using namespace std;
int testScore1, testScore2, testScore3, testScore4, testScore5;
double avg;
char grade;

double getAvg(int testScore1, int testScore2, int testScore3, int testScore4, int testScore5){
    avg = (testScore1 + testScore2 + testScore3 + testScore4 + testScore5)/5;
    return avg;
}
char getGrade(double avg){
    if (avg >= 90){
        grade = 'A';
        cout << 'A' << endl;
    }else if (avg >= 80){
        grade = 'B';
        cout << 'B' << endl;
    }else if (avg >= 70){
        grade = 'C';
        cout << 'C' << endl;
    }else if (avg >= 60){
        grade = 'D';
        cout << 'D' << endl;
    }else{
        grade = 'F';
        cout << 'F' << endl;
    }
    return grade;
}

int main(){
    
    ifstream myFile;
    myFile.open("scores.csv");
    
    
    if(!myFile.is_open()){
        cout << "Error" << endl;
    }
    string testScore1, testScore2, testScore3, testScore4, testScore5;
    while (myFile.good()) {
        
        getline(myFile, testScore1, ',');
        getline(myFile, testScore2, ',');
        getline(myFile, testScore3, ',');
        getline(myFile, testScore4, ',');
        getline(myFile, testScore5, '\n');

    }
    
        cout<< setw(15) <<" Test scores"<<endl;
        cout<<"--------------------"<<endl;
        cout<< " 1   2   3   4   5   Avg  Grade"<<endl;
        cout<<"=== === === === === ===== ====="<<endl;
        cout<< " "<< testScore1<< "  "<< testScore2 << "  "<< testScore3 << "  "<< testScore4 << "  "<< testScore5<< "  " << getAvg << "  " << getGrade <<endl;


    return 0;
}
c++ csv
2个回答
2
投票

您在 while 循环之外打印值,这意味着您永远不会保存以前的值。你的程序本质上是在说:
“将 t1 设置为测试分数第 0 行、第 0 列,将 t2 设置为第 1 行、第 0 列,等等...”
循环重新开始,现在开始:
“将 t1 设置为测试分数第 0 行、第 1 列,将 t2 设置为第 1 行、第 1 列,等等...”
你看到问题了吗?每次循环运行时都会覆盖变量,而不保存它们。然后程序只打印最后一行,因为这就是循环结束时变量的内容。

您可能想通过使用二维数组来解决这个问题。然后,您可以使用嵌套循环将每个点设置为相应的值。这些信息足以弄清楚其余部分吗?如果没有请告诉我。

总体思路:

new int[行数][列数]数组;
for(int i = 0; i = 行数; i++)
for(int j=0; j=列数; j++)
array[i][j] = 此处获取行代码
闭环。


1
投票

答案已经给出并被接受。

为了完整起见,我将展示您的代码的重构和工作版本。

我没有使用数组。只是循环和函数。

#include <iostream>
#include <fstream>
#include <iomanip>

double getAvg(int testScore1, int testScore2, int testScore3, int testScore4, int testScore5){
    double avg = (testScore1 + testScore2 + testScore3 + testScore4 + testScore5)/5.0;
    return avg;
}
char getGrade(double avg){
    char grade = 'F';
    if (avg >= 90){
        grade = 'A';
    }else if (avg >= 80){
        grade = 'B';
    }else if (avg >= 70){
        grade = 'C';
    }else if (avg >= 60){
        grade = 'D';
    }
    return grade;
}

int main(){
    
    std::ifstream myFile("scores.csv");

    if(!myFile){
        std::cerr << "\nError: Could not open input file\n";
    }
    else {

        std::cout<< std::setw(15) <<" Test scores\n--------------------\n 1   2   3   4   5   Avg  Grade\n=== === === === === ===== =====\n";
       
        int testScore1, testScore2, testScore3, testScore4, testScore5;
        char comma1, comma2, comma3, comma4;
        
        // Read all values in one line, then next line, next line and so on
        while (myFile >> testScore1 >> comma1 >> testScore2 >> comma2 >> testScore3 >> comma3 >> testScore4 >> comma4 >> testScore5) {
            
            // Calculate
            double average = getAvg(testScore1, testScore2, testScore3, testScore4, testScore5);
            char grade = getGrade(average);
            std::cout<< " "<< testScore1<< "  "<< testScore2 << "  "<< testScore3 << "  "<< testScore4 << "  "<< testScore5<< "  " << average << "  " << grade << '\n';
        }
    }
    return 0;
}
© www.soinside.com 2019 - 2024. All rights reserved.