为什么fscanf读数为0?

时间:2016-03-31 04:37:32

标签: c file io std scanf

我正在创建一个可以逐个文件读取文件的简单程序。文件的每一行格式为:整数,整数,字符。例如,使用如下文件:

1 2 A
2 3 B

该计划的预期输出应为:

1 2 A
2 3 B

但它正在打印

0 2 A
0 3 B 

我该如何解决?

#include <unistd.h>
#include <fcntl.h>
#include <stdlib.h>
#include <string.h>
#include <inttypes.h>
#include <stdint.h>
#include <time.h>    

int main(int argc, char** argv) {

    char const* const fileName = argv[1];
    FILE* file = fopen(fileName, "r");

    char str[1];
    int key;
    int val;

    while (fscanf(file, "%d %d %s\n", &key, &val, str) != EOF) {

        printf("Read Integer %d \n", key );
        printf("Read Integer %d \n", val );
        printf("Read String %s \n", str );
    }


   fclose(file);

   return(0);
}

2 个答案:

答案 0 :(得分:2)

您将str声明为char [1],这是错误的。

您需要分配更大的str以容纳'\0'。如下更改声明应解决问题。

char str[2];  /* Or may be larger */
/*       ^    */

最好从格式字符串'\n'中删除scanf为:

while (fscanf(file, "%d %d %s", &key, &val, str) == 3)
/*                           ^                   ^^^^  */

答案 1 :(得分:2)

您需要更大的字符串,需要检查argc值,并且需要更好的格式fscanf()。最好还是检查fscanf()返回是3。

#include <stdio.h>

#define N 500
#define XSTR(n) STR(n)
#define STR(n) #n

int main(int argc, char** argv)
{
    if (argc < 2)
    {
        fprintf(stderr, "I need one argument.\n");
        return 1;
    }

    char const* const fileName = argv[1];
    FILE* file = fopen(fileName, "r");

    char str[N + 1];
    int key;
    int val;

    // "%d %d %" XSTR(N) "s" expands as "%d %d %500s"
    while (fscanf(file, "%d %d %" XSTR(N) "s", &key, &val, str) == 3)
    {

        printf("Read Integer %d \n", key );
        printf("Read Integer %d \n", val );
        printf("Read String %s \n", str );
    }


   fclose(file);

   return(0);
}

编辑:我添加了宏,以便在更改N时更新格式。