要在Linux c 程序里面实现文本的字符串读写,百度一下,都是比较简单的字符串处理,并没有类似的说明,后来换成bing 找到一些蛛丝马迹
http://bbs.csdn.net/topics/390016741
这个CSDN的 topic 不错
虽然没有直接达到我的要求,至少我能找到重要的线索了
用seek 去定位
FILE *fp;
char line[256],*pStr;
const char str1[] = "a=1";
const char str2[] = "a=100\n";
const char delete[]="\n";
//读取行 匹配
if(fgets(line, 256, fp))
{
pStr = strstr(line, str1);
}
//匹配成功 处理
strcpy(line, str1);
fseek(fp, -5, SEEK_CUR);//重定位
fputs(str2,fp)
至于没有修改到的部分就要先读出来,后面再写进去了。
函数名: strstr
函数原型:
语法:
str1: 被查找目标 string expression to search.
str2: 要查找对象 The string expression to find.
返回值:若str2是str1的子串,则返回str2在str1的首次出现的地址;如果str2不是str1的子串,则返回NULL。
例子:
显示的是: 34xyz
以下代码实现将文件中第6行处插入一行, 即原来的第6行以后依次往后移一行.
fgets
从文件结构体指针stream中读取数据,每次读取一行。读取的数据保存在buf指向的字符数组中,每次最多读取bufsize-1个字符(第bufsize个字符赋'\0'),如果文件中的该行,不足bufsize个字符,则读完该行就结束。如若该行(包括最后一个换行符)的字符数超过bufsize-1,则fgets只返回一个不完整的行,但是,缓冲区总是以NULL字符结尾,对fgets的下一次调用会继续读该行。函数成功将返回buf,失败或读到文件结尾返回NULL。因此我们不能直接通过fgets的返回值来判断函数是否是出错而终止的,应该借助feof函数或者ferror函数来判断。
#include int main(void) { FILE *fp; int i; char buf[1024]; // 假设每行不超过1024字节, 根据情况调节大小 if (!(fp = fopen("./a.txt", "r+"))) { // 尝试以读写方式打开文件. fprintf(stderr, "Open failed.\n"); return 1; } for (i = 0; i < 5; i++) { // 循环5次, 读掉前5行 fgets(buf, 1024, fp); // 读取一行 } // 此时文件指针指向第6行行首 long offset = ftell(fp); // 记录文件指针位置, 因为后面还要读, 文件指针会移走 // 这里为了程序易懂, 假设后面不超过100行, 每行不超过1024字节, 否则需要用链表或二重 //指针的方式, 可以保证不浪费空间, 但代码就较复杂 char save[100][1024]; i = 0; // 清0, 记录后面共有多少行 while ((fgets(save[i], 1024, fp))) { // 循环读取文件, 直到fgets返回NULL表示读完 i++; } printf("请输入要插入的数据内容:"); fgets(buf, 1024, stdin); // 接收键盘输入的内容 // 由于读完文件后, 文件指针指向文件尾, 这里重新定位到之前保存的位置 fseek(fp, offset, SEEK_SET); fputs(buf, fp); // 写要插入的数据 int j; for (j = 0; j < i; j++) { // 之前保存的数据, 依次往后面写 fputs(save[j], fp); } return 0; }