欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    简单的行编辑器源程序.docx

    • 资源ID:5144776       资源大小:15.79KB        全文页数:12页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    简单的行编辑器源程序.docx

    1、简单的行编辑器源程序 SANY GROUP system office room 【SANYUA16H-SANYHUASANYUA8Q8-SANYUA1688】简单的行编辑器源程序#include #include #include #define MAXL 100 /*最大行数*/#define MAXC 80 /*每行最大字符数*/#define true 1char linesMAXLMAXC=0;void edit(char (*lines)MAXC);void modify(char (*lines)MAXC);void mydelete(char (*lines)MAXC);voi

    2、d search(char (*lines)MAXC);void replace(char (*lines)MAXC);void savetofile(char (*lines)MAXC);void myexit(char (*lines)MAXC);void menu(char (*lines)MAXC)int selection;dosystem(cls);puts(tt*MUNU*nn);puts(tt1.Edit new line);puts(tt2.Replace line);puts(tt3.Delete line);puts(tt4.Search line);puts(tt5.M

    3、odify data);puts(tt6.Save);puts(tt0.Exit);puts(nntt*n);printf(Please select a number: bb);doscanf(%d,&selection);if(selection6) printf(Invalid selection!Please try again );printf(and select a number:bbn);else break;while(true);switch(selection) case 1:edit(lines);break;case 5:modify(lines);break;cas

    4、e 3:mydelete(lines);break;case 4:search(lines);break;case 2:replace(lines);break;case 6:savetofile(lines);break;case 0:myexit(lines); while(true);int readfile(char (*lines)MAXC,FILE *pfile) int i=0;while(!feof(pfile)fgets(linesi,MAXC,pfile); /*if(!strstr(linesi,n) return 1;*/i ;return 0;/*主函数*/main(

    5、) FILE *pfile; pfile=fopen(Linedit.txt,a ); readfile(lines,pfile); fclose(pfile); menu(lines);/*编辑*/void edit(char (*lines)MAXC) int i,index; /*system(cls);*/ clrscr(); for(i=0,index=0;iMAXL;i ) if(linesi0!=0) index ; printf(%d: %s,index,linesi); printf(nnPlease type a new line:n); fflush(stdin); fo

    6、r(i=0;iMAXL;i ) if(linesi0=0) /*每行第一个字符作为标志位 空行可写入*/ fgets(linesi,MAXC,stdin); return; else continue; /*替换*/void replace(char (*lines)MAXC) int i; int indline; int j,k; do /*system(cls); */ clrscr(); /*打印所有 */ for(i=0;iMAXL;i ) if(linesi0!=0) printf(%d: %s,i 1,linesi); printf(nnWhich line do you pre

    7、fer to replace?(To quit please input 0) bb); scanf(%d,&indline); if(indline=0) return; else for(j=0,k=0;jMAXL;j ) if(linesj0!=0) k ; if(k=indline) printf(nnThe line to be replaced is: n%s,linesj); printf(Please type your new line:n); memset(linesj,0,MAXC); fflush(stdin); fgets(linesj, MAXC, stdin);

    8、break; while(true); /*删除*/void mydelete(char (*lines)MAXC) int i,index; int indline; int j,k; do /*system(cls);*/ clrscr(); for(i=0,index=0;iMAXL;i ) if(linesi0!=0) index ; printf(%d: %s,index,linesi); printf(nnWhich line do you prefer to delete?(To quit please input 0) bb); scanf(%d,&indline); if(i

    9、ndline=0)return; else for(j=0,k=0;jMAXL;j ) if(linesj0!=0) k ; if(k=indline) printf(The line to be deleted is: n%sn,linesj); memset(linesj,0,MAXC); system(pause); break; while(true);/*查找*/void search(char (*lines)MAXC) int i,index; int indline; int j,k; do /*system(cls);*/ clrscr(); for(i=0,index=0;

    10、iMAXL;i ) if(linesi0!=0) index ; printf(%d: %s,index,linesi); printf(nnWhich line do you want to search?(To quit please input 0) bb); scanf(%d,&indline); if(indline=0)return; else for(j=0,k=0;jMAXL;j ) if(linesj0!=0) k ; if(k=indline) printf(The line to be searched is: n%sn,linesj); system(pause); b

    11、reak; while(true);/*修改*/*在sSrc中用sReplaceStr替换sMatchStr */int modifystr(char *sSrc,char *sMatchStr,char *sReplaceStr) int StringLen; char caNewStringMAXC; char *FindPos = strstr(sSrc,sMatchStr); if(!FindPos)|(!sMatchStr) return -1; while(FindPos) memset(caNewString,0,sizeof(caNewString); StringLen=Fi

    12、ndPos-sSrc; strncpy(caNewString,sSrc,StringLen); strcat(caNewString,sReplaceStr); strcat(caNewString,FindPos strlen(sMatchStr); strcpy(sSrc,caNewString); FindPos = strstr(sSrc,sMatchStr); return 0;void modify(char (*lines)MAXC) int i,indline; char bufMAXC; int k; int j; char* token=0; char searchMAX

    13、C,replaceMAXC; do /*system(cls); */ clrscr(); for(i=0;iMAXL;i ) if(linesi0!=0) printf(%d: %s,i 1,linesi); printf(nnWhich line do you prefer to modify?(To quit please input 0) bb); scanf(%d,&indline); if(indline=0) return; else for(j=0,k=0;jMAXL;j ) if(linesj0!=0) k ; if(k=indline) printf(nnThe line

    14、to be replaced is: n%s,linesj); printf(nnInput the search string and the replace );printf(To quit please input q):); memset(buf,0,MAXC); fflush(stdin); fgets(buf, MAXC, stdin); k= strlen(buf)-1; if(bufk=n) bufk=0; if(*buf=q&*(buf 1)=0) return; memset(search,0,MAXC); memset(replace,0,MAXC); token =st

    15、rtok(buf, ); strcpy(search,token); token =strtok(NULL, ); strcpy(replace,token); modifystr(linesj,search,replace); break; while(true); void savetofile(char (*lines)MAXC) FILE *pfile; int i; pfile=fopen(Linedit.txt,w ); for(i=0;iMAXL;i ) if(linesi0!=0) fputs(linesi,pfile); fclose(pfile); printf(nThe lines has been saved.n); system(pause);void myexit(char (*lines)MAXC) char c; printf(Save the lines to the file?(y/n); fflush(stdin); c=getchar(); if(c=n) exit(1); savetofile(lines); exit(1);


    注意事项

    本文(简单的行编辑器源程序.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开