1

我有下面的代码。我想逐行写入所有新数据,我该怎么做?我的代码工作正常,但它将数据彼此相邻写入。

////////////////////////////////////
char timedate[13];
char USERID[] ="100050"; 
char *p;
p=fetch_time(); //the function returns a string (char[13])
strcpy(timedate, p);

char log_sensor_event[20];
sprintf(log_sensor_event, "%s %s",timedate, USERID);

FILE *fp2;
fp2=fopen("/home/eagle/Desktop/log_file.txt", "ab");
if(fp2 == NULL){
    perror("log_file.txt open failed");
    exit(EXIT_FAILURE);
}
write(log_sensor_event, sizeof(log_sensor_event[0]), sizeof(log_sensor_event)/sizeof>(log_sensor_event[0]), fp2);
fputc('\n', fp2);
fclose(fp2);
4

3 回答 3

3

您创建没有换行符的字符串:

sprintf(log_sensor_event, "%s %s",timedate, USERID);

试试这个:

sprintf(log_sensor_event, "%s\n %s",timedate, USERID);
于 2012-04-30T20:45:27.957 回答
2

您需要'\n'在字符串之间插入换行符 ( ) :

sprintf(log_sensor_event, "%s %s\n",timedate, USERID);

注意结尾的“\n”。

于 2012-04-30T20:46:09.590 回答
1

为什么不更换你的

char log_sensor_event[20];
sprintf(log_sensor_event, "%s %s",timedate, USERID);

...
write(log_sensor_event, sizeof(log_sensor_event[0]), sizeof(log_sensor_event)/sizeof>(log_sensor_event[0]), fp2);
fputc('\n', fp2);

只需通过

fprintf(fp2, "%s %s\n", timedate, USERID);

这避免了很多调用和本地缓冲区。

I/O 的缓冲可以用 设置setvbuf

于 2012-05-01T09:04:40.200 回答