我正在创建一个可以逐个文件读取文件的简单程序。文件的每一行格式为:整数,整数,字符。例如,使用如下文件:
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);
}
答案 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时更新格式。