我正在尝试从以下文件中提取 [HOCKEY] 和 [done with HOCKEY] 之间的文本:
sport.txt
:
[HOCKEY]
a=10
b=20
c=30
d=45
[done with HOCKEY]
[SOCCER]
a=35
b=99
c=123
d=145
[done with SOCCER]
使用以下代码,我将能够检查该行是否为 [HOCKEY],但我无法记录 [HOCKEY] 和 [done with HOCKEY] 之间第一行和最后一行的位置
#include<stdio.h>
int main()
{
FILE *infile;
char start, end;
char *sport="[]";
char line_buffer[BUFSIZ]; /* BUFSIZ is defined if you include stdio.h */
int line_number,i;
infile = fopen("sport.txt", "r");
printf("Opened file for reading\n");
line_number = 0;
while (fgets(line_buffer, sizeof(line_buffer), infile)) {
++line_number;
/* note that the newline is in the buffer */
if (line_buffer=="[HOCKEY]")
{
start=line_buffer;
printf("Found start %s",start);
}
if (line_buffer=="[done with HOCKEY]")
end=line_buffer;
while(start<end){
printf("%c",start);
start++;
system("PAUSE");
}
}
return 0;
}
最佳答案
第一行是
[HOCKEY]
之后的第一行。还有最后一行是
[done with HOCKEY]
之前的最后一行。
所以你需要的是一行一行地读取文件。当您读取[HOCKEY]
时,您正在接近您需要的真实数据,并开始读取并存储下一行的数据。继续此步骤,直到您读到[done with HOCKEY]
并停止。
关于c - 在 C 中读取文件并提取两行特定文本之间的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21421060/