读取包含小数的文件时出现问题

Problem reading a file containing decimals

本文关键字:问题 文件 包含 小数 读取      更新时间:2023-10-16

我有一个问题,试图找出为什么我的文件返回0而不是文件内的数字,这是我在c++中读取文件的代码:

    #include <cstdlib>
    #include <iostream>
    #include <fstream>
    #include <string>
    using namespace std;
    string cfile;
    int cnum1,cnum2,cnum3,cnum4;
    bool fired = false;

    /*
     * 
     */
    void printMatrix(double **x, int n)
    {
        int size = n;
        for(int i=0; i<size; i++)
        {
            for(int j=0; j<size; j++)
            {
                std:: cout << x[i][j] << " " ;
            }
            std:: cout << std::endl;
        }

    }
    void readFile(string file,double **x, int n)
    {
        std::ifstream myfile(file.c_str());
        int size = n;
        for(int i=0; i<size; i++)
        {
            for(int j=0; j<size; j++)
            {
                myfile >> x[i][j];
            }
        }
    }
    void GetCommandLineArguments(int argc, char **argv,string &file, int &n, int &k, int &m, int &i)
    {
        if( argc == 6 )
        {
            cfile = argv[1];
            cnum1 = atoi(argv[2]);
            cnum2 = atoi(argv[3]);
            cnum3 = atoi(argv[4]);
            cnum4 = atoi(argv[5]);
        }
        file = cfile;
        n = cnum1;
        k = cnum2;
        m = cnum3;
        i = cnum4;
    }

    int main(int argc, char** argv) {
        int k; //Factor of n
        int m; //Innner matrix size
        int i; //Iteration
        int n; //Matrix Size
        string file;

        GetCommandLineArguments(argc, argv, file, n, k, m, i);
        double **matrix;
        matrix = new double*[n];
        for(int i = 0; i<n; i++)
            matrix[i] = new double[n];
        for(int j=0; j<n; j++)
            for(int i=0; i<n;i++)
                matrix[i][j] = 0;
        readFile(file, matrix, n);
        printMatrix(matrix, n);

        return 0;
    } 

下面是我的文件的一个示例,其中包含我想从中提取的值:

20.0
20.0
20.0
20.0
20.0
200.0
20.0
200.0

希望有人能帮助我,因为我研究了一些关于这个的信息,并没有真正找到一个解决方案。

您的读取和打印代码似乎可以工作,但是您的命令行读取代码可能有一些问题。

我运行你的代码没有得到命令行参数。下面的代码,基本上是从你的主代码复制粘贴过来的,除了获取命令行参数。

int main()
{
    double **matrix;
    std::string file = "test.dat";
    int n = 5;
    matrix = new double*[n];
    for(int i = 0; i<n; i++)
        matrix[i] = new double[n];
    for(int j=0; j<n; j++)
        for(int i=0; i<n;i++)
            matrix[i][j] = 0;
    readFile(file, matrix, n);
    printMatrix(matrix, n);
   return 0;
}
使用您提供的输入,我得到输出:

20 20 20 20 20 20
200 20 200 00 00


0 0 0 0 0

然而看着你的命令行参数读取代码,我可以看到一些潜在的问题。首先使用atoi()。当atoi失败时,它返回0。你知道这个代码是有效的吗?一切都被正确初始化了吗?或者是atoi在输入上失败,导致n为0,因此没有任何东西被读入?(您可能希望查看stringstreams来做这种事情)。

此外,当argc不为6时,您将静默失败并从未初始化的全局内存中读取。这些内存是垃圾。你知道这是不可能的吗?如果你正在做:

  your.exe test.dat 5

则不会从命令行读取5,因为argc不是6。你是否总是像测试时一样传递6个参数?也许不是,因为在当前状态下,你的代码实际上只需要文件名和大小。

最重要的是,看看你是否从命令行中得到了你所期望的。

PS这是g++:

$ g++——versiong++ (Ubuntu/Linaro 4.4.4-14 Ubuntu)4.4.5 Free Software Foundation, Inc.版权所有(C) 2010这是免费的软件;请参阅源代码进行复制条件。没有保修;不即使是为了适销性或适用性为了一个特殊的目的。

我建议这样修复,使事情更健壮:

#include <fstream>
#include <iostream>
#include <string>
#include <stdexcept>
template <size_t size>
    void readFile(std::string file, double (&x)[size][size])
{
    std::ifstream myfile(file.c_str());
    for(int i=0; i<size; i++)
    {
        for(int j=0; j<size; j++)
        {
            if (!(myfile >> x[i][j]))
                throw std::runtime_error("Couldn't read double from " + file);
        }
    }
}
int main(int argc, const char *const args[])
{
    try
    {
        double data[10][10];
        readFile("input.txt", data);
    } catch(const std::exception& e)
    {
        std::cerr << "Whoops: " << e.what() << std::endl;
        return 255;
    }
    return 0;
}

您的输入操作符将读取数字,但将换行符保留在文件中。

请参阅以下答案,了解如何在读取值后ignore()行尾

为什么我们要在读取输入后调用cin.clear()和cin.ignore() ?