我试图找到一种方法来选择使用C的文本文件的最后一行(不是c ++或c#,只是C),我很难找到一种方法来做到这一点,如果有人可以帮我的话有了这个问题,我将非常感激,谢谢! (顺便说一下,我想要做的一个很好的例子,这将类似于尾巴-n 1将在bash中做什么)
答案 0 :(得分:6)
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void main(int argc, char *argv[])
{
FILE *fd; // File pointer
char filename[] = "./Makefile"; // file to read
char buff[1024];
if ((fd = fopen(filename, "r")) != NULL) // open file
{
fseek(fd, 0, SEEK_SET); // make sure start from 0
while(!feof(fd))
{
memset(buff, 0x00, 1024); // clean buffer
fscanf(fd, "%[^\n]\n", buff); // read file *prefer using fscanf
}
printf("Last Line :: %s\n", buff);
}
}
我正在使用Linux。 CMIIW
答案 1 :(得分:5)
没有直接的方法,但我首选的方法是:
答案 2 :(得分:1)
E.g。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#ifndef max
#define max(a, b) ((a)>(b))? (a) : (b)
#endif
long GetFileSize(FILE *fp){
long fsize = 0;
fseek(fp,0,SEEK_END);
fsize = ftell(fp);
fseek(fp,0,SEEK_SET);//reset stream position!!
return fsize;
}
char *lastline(char *filepath){
FILE *fp;
char buff[4096+1];
int size,i;
long fsize;
if(NULL==(fp=fopen(filepath, "r"))){
perror("file cannot open at lastline");
return NULL;
}
fsize= -1L*GetFileSize(fp);
if(size=fseek(fp, max(fsize, -4096L), SEEK_END)){
perror("cannot seek");
exit(1);
}
size=fread(buff, sizeof(char), 4096, fp);
fclose(fp);
buff[size] = '\0';
i=size-1;
if(buff[i]=='\n'){
buff[i] = '\0';
}
while(i >=0 && buff[i] != '\n')
--i;
++i;
return strdup(&buff[i]);
}
int main(void){
char *last;
last = lastline("data.txt");
printf("\"%s\"\n", last);
free(last);
return 0;
}
答案 3 :(得分:0)
如果您使用的是* nix操作系统,则可以使用命令“last”。有关详细信息,请参见“最后”手册页。 如果要将功能集成到另一个程序中,可以使用'system'调用来执行'last'并获得结果。
答案 4 :(得分:0)
一种简单而低效的方法是将每一行读入缓冲区
当最后一次读取给你EOF
时,你在缓冲区中有最后一行。
Binyamin Sharet的建议更有效率,但实施起来有点困难。