C: Read from textfile into a struct array

后端 未结 2 1687
陌清茗
陌清茗 2021-01-25 12:35

The program I am making is supposed to read in numbers from a text file and save the total number of numbers, the average value of the numbers in a struct.

I have a stru

相关标签:
2条回答
  • 2021-01-25 13:08

    If you see a reference of fscanf, you will see that it returns the number of items successfully scanned, and not the value you just scanned.

    That means you have to check differently for your ending condition.

    You also should not loop while (!feof(...)), as the end-of-file condition will not be set until you already tried to read beyond the end of the file.

    Instead you could do something like this:

    while (fscanf(tsin, " %f", &in_last) > 0)
    {
        if (in_last == 0.0f)
            ++x;
        else
        {
            /* The rest of your code */
        }
    }
    

    This will read until you reach end-of-file, or there is an error, and increase the index once you read 0.0. The leading space in the fscanf format string make fscanf skip whitespace (spaces, tabs, newlines).


    There are also a couple of other problems with your code. For example, you donät update the average variable. The value of serie[x].totnr may not be initialized, and so increasing it (and using it in operations in general) will in that case be undefined as well. And then you use sizeof(series) which will not work, as series is not actually an array in the function but a pointer, so the sizeof operator returns the size of the pointer and not the number of entries in the array. Instead return x which is now the size of the array.

    0 讨论(0)
  • 2021-01-25 13:15

    fscanf returns the number of successfully read items, not the value.

    while (fscanf(tsin, "%f", &in_last) != 0.0)
    

    should be:

    while (fscanf(tsin, "%f", &in_last) != 1)
    

    Additionally you can not compare a float against a constant value. That doesn't work in most cases. So you need to choose a delta, and then check if your float is within that range.

    I think you also don't want to return sizeof(serie) because this is a constant value you already know when calling. More likely you want to return x-1 to indicarte the number of values read. If the feof condition is met, you haven't read anything and x will be 1 (because of your loop).

    BTW: Your program might have a problem if you don't have a fixed size of lines in your textfile and know beforehand how big the array must be. You don't allocate the array while reading, but you pass it alerady in, so when x increases, you might overrun the array.

    0 讨论(0)
提交回复
热议问题