我是C的新手,我正在尝试编写一个程序,它将从文件中读取数据并将它们存储在一个数组中(所以我以后可以使用它们)。
#include <stdio.h>
#include <stdlib.h>
int day[3], month[3], year[3], hour[3], minute[3], second[3];
float value[3];
int main()
{
// Open the file for read
FILE* file1 = fopen("test.txt", "r");
// Safety check
if (file1 == NULL)
{
printf("Error: file1 == NULL\n");
getchar();
return 0;
}
// Open the new file for write
FILE* file2 = fopen("new.txt", "w");
// Safety check
if (file2 == NULL)
{
printf("Error: file2 == NULL\n");
getchar();
return 0;
}
int j = 0;
for (j = 0; j < 4; j++)
{
int count = fscanf(file1, "%d-%d-%d %d:%d:%d %f", &day[j], &month[j], &year[j], &hour[j], &minute[j], &second[j], &value[j]);
printf("%d-%d-%d %d:%d:%d %f\n", day[j], month[j], year[j], hour[j], minute[j], second[j], value[j]);
// Check for finising early
if (count == EOF)
{
printf("EOF");
}
}
// Close the original file
fclose(file1);
// Close the target file
fclose(file2);
getchar();
}
该文件包含以下格式的数据:
20-03-17 08:49:01 28,515
20-03-17 08:49:31 29,1837
20-03-17 08:50:01 27,845
评论后编辑:
现在代码不再崩溃,它几乎完美无缺!
这就是出现的结果:
20-3-17 8:49:1 28.514999
20-3-17 8:49:31 29.183701
20-3-17 8:50:1 27.844999
1105469112-1-20 17:8:49 0.000000
有没有办法解决小数问题? 什么是最后一行?
感谢您的时间!
答案 0 :(得分:1)
在这里:
for (j = 0; j < 3; j++)
{
int count = fscanf(file1, "%i-%i-%i %i:%i:%i %f ", day[j], month[j], year[j], hour[j], minute[j], second[j], value[j]);
printf("%d-%d-%d %d:%d:%d %f\n", day[j], month[j], year[j], hour[j], minute[j], second[j], value[j]);
// Check for finising early
if (count == EOF)
{
printf("EOF");
}
}
将&
放在您想要阅读的每个变量之前。
像:
for (j = 0; j < 3; j++)
{
int count = fscanf(file1, "%i-%i-%i %i:%i:%i %f ", &day[j], &month[j], &year[j], &hour[j], &minute[j], &second[j], &value[j]);
printf("%d-%d-%d %d:%d:%d %f\n", day[j], month[j], year[j], hour[j], minute[j], second[j], value[j]);
// Check for finising early
if (count == EOF)
{
printf("EOF");
}
}
问题编辑后:
好的,问题是您的数据文件(test.txt
)格式化为
20-03-17 08:49:01 28,515
,不是
20-03-17 08:49:01 28.515
因此%f
只能读取28
,而不是28.515
(因为,
不用于浮点数)。您有两种选择:(1)在数据文件中将28,515
更改为28.515
(2)单独阅读28
和515
。我认为第一选择会很好。
答案 1 :(得分:0)
我就是这样做的,但我自己肯定不是C语言编程的大师。
我认为最好是使用stat
,但文件大小等。
您可以执行以下操作:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/stat.h>
#define dir "/path/to/file"
#define MAX_WORDS 32
int main() {
FILE *fp;
struct stat stz;
stat(dir, &stz);
int charz;
char data[4096], buff[8];
char *words[MAX_WORDS];
if (stz.st_size > 0) {
fp = fopen(dir, "r");
fseek(fp, 0, SEEK_SET);
for (i = 0; i < stz.st_size; i++) {
charz = fgetc(fp);
if (charz == 10) {
strcat(data, " ");
} else {
sprintf(buff, "%c", charz);
strcat(data, buff);
}
}
fclose(fp);
words[0] = strtok(data, " ");
for (i = 0; i < MAX_WORDS; i++) {
if (!words[i]) {
break;
}
words[i+1] = strtok(NULL, " ");
}
} else {
printf("No data available in given directory");
}
return 0;
}
这将每个字节放入变量charz
,然后放入单个字符缓冲区,如果字符不等于10(NewLine),则将所述字符连接到字符串data
的末尾,否则,它增加了一个空格或分隔符。
然后,您可以通过拆分字符串来初始化单词数组。