linux c语言定位显示字符,Linux c语言实现修改文本字符串
要在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)
至于沒有修改到的部分就要先讀出來,后面再寫進去了。
包含文件: string.h
函數名: 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;
}
總結
以上是生活随笔為你收集整理的linux c语言定位显示字符,Linux c语言实现修改文本字符串的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux怎么卸载yam,linux 基
- 下一篇: linux永久设置nlslang,【图片