你能帮我编写一个删除文本文件中某一行的程序。
我打算使用:
fgets从文本文件中捕获一行并将其存储在一个数组中,但我很困惑fgets如何将该行存储在一个数组中(它是否捕获该行并将其存储在第一个索引和下一个索引中)它捕获一行的时间会存储到下一个索引还是只覆盖数组的第一个索引?)
如果该行存储在不同的索引中,那么我将有一个条件将用户的输入与捕获的fgets行进行比较,如果它相等,它将跳过该行并执行规则直到达到文件的结尾。
然后我将关闭文本文件,如fclose(stream),并将其重新打开为“wt”以覆盖文件中写入的所有内容。
我是否拥有正确的逻辑......或者您可以建议更好的解决方案...... 希望你能帮助我理解fgets如何将数据存储在数组中......
顺便说一下,这是我正在尝试进行测试的代码:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
struct studentinfo{
char id[8];
char name[30];
char course[5];
}s1;
int main(void){
FILE *stream = NULL;
stream = fopen("studentinfo.txt", "rt");
char arr[100];
int i=0;
while(!feof(stream)){
fgets(arr, 100, stream);
printf("%s", arr);
}
fclose(stream);
/*planning to reopen the stream but will change "rt" to "wt"*/
getch();
}
答案 0 :(得分:1)
嗯,磁盘空间允许,我会做以下事情:
这避免了将(几乎)整个文件保留在内存中的需要。
它也不会遇到这样的问题:如果你的程序在写入文件的过程中死亡(或被杀死),输入文件的一部分可能会丢失。