经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C 语言 » 查看文章
用c语言基本实现wc.exe功能
来源:cnblogs  作者:机智  时间:2018/9/25 20:33:28  对本文有异议

网址:https://github.com/3216005214/wc.exe

wc项目要求

wc.exe 是一个常见的工具,它能统计文本文件的字符数、单词数和行数。这个项目要求写一个命令行程序,模仿已有wc.exe 的功能,并加以扩充,给出某程序设计语言源文件的字符数、单词数和行数。

实现一个统计程序,它能正确统计程序文件中的字符数、单词数、行数,以及还具备其他扩展功能,并能够快速地处理多个文件。
具体功能要求:
程序处理用户需求的模式为:

wc.exe [parameter] [file_name]

 基本功能列表:

wc.exe -c file.c     //返回文件 file.c 的字符数

wc.exe -w file.c    //返回文件 file.c 的词的数目  

wc.exe -l file.c      //返回文件 file.c 的行数

扩展功能:
    -s   递归处理目录下符合条件的文件。
    -a   返回更复杂的数据(代码行 / 空行 / 注释行)。

空行:本行全部是空格或格式控制字符,如果包括代码,则只有不超过一个可显示的字符,例如“{”

代码行:本行包括多于一个字符的代码。

注释行:本行不是代码行,并且本行包括注释。一个有趣的例子是有些程序员会在单字符后面加注释:

    } //注释
在这种情况下,这一行属于注释行。

[file_name]: 文件或目录名,可以处理一般通配符。

高级功能:

 -x 参数。这个参数单独使用。如果命令行有这个参数,则程序会显示图形界面,用户可以通过界面选取单个文件,程序就会显示文件的字符数、行数等全部统计信息。

需求举例:
  wc.exe -s -a *.c

返回当前目录及子目录中所有*.c 文件的代码行数、空行数、注释行数。

已实现wc项目要求

1、计算文件字符数

2、计算文件单词数

3、计算文件行数

4、计算文件空行数

遇到的困难及解决办法

?  困难描述

大学前两年对课程学习的疏忽,对c语言的知识的记忆已经大大减少,以至于老师要求我们做这个单人项目的时候,心里是慌的,因为对c语言等编程的不熟悉,所以我要花几天时间重新把丢下的知识重新拾取回来,所以,我也就比别人的时间要更紧张。首先我先做了下尝试,尝试用JAVA和C语言写这个项目,最后还是选择了C语言。在写代码的过程中,有许多新的函数未接触过,需要花时间去了解。还有github的使用方法也不是太了解,也要花时间去做。对于传参的形式也是想了很久,做出了很多尝试。

?  做过哪些尝试

对于要重拾C语言知识这件事情,幸好大一的时候买了一本较为详细的C语言教科书,帮助我能更快的把丢下的知识拿回来。当算法真的不懂的时候,到网上参考了一些代码,然后把它理解为自己的东西再写到自己的代码中。在把第一个基本功能写出的时候,运行的时候发现总是只能读取文件中的第一个字符,通过不断的检查,尝试,终于才可以正确的实现计算字符数的功能。对于传参形式,首先尝试用了指针,然后发现行不通(可能以我现在水平不能很好的使用这种方法),最后用了数组,选择了一种比较简单的方式。在函数的选择方面,也是一个一个认为可以实现的函数去尝试(虽然最后没有用到多少函数)

?  是否解决

拓展功能的注释行和代码行的计数算法尚未解决,空行的计数方法存在缺陷。基本功能已实现。

?  有何收获

了解并基本掌握关于处理文件的算法函数

重拾C语言相关知识

认识到需要不断巩固知识的重要性

关键代码及说明

 

  1. int main(){//主函数
  2. char input[10],File[200];
  3. while(1){
  4. printf("请输入用户命令:wc.exe-");
  5. scanf("%s",&input);
  6. if(input[0]=='c'){
  7. printf("请输入文件名:");
  8. scanf("%s",&File);
  9. int charcount=0;
  10. charcount=CharCount(File);
  11. printf("文件的字符数为:%d\n",charcount);
  12. continue;
  13. }
  14. if(input[0]=='w'){
  15. printf("请输入文件名:");
  16. scanf("%s",&File);
  17. int wordcount=0;
  18. wordcount=WordCount(File);
  19. printf("文件的词数为:%d\n",wordcount);
  20. continue;
  21. }
  22. if(input[0]=='l'){
  23. printf("请输入文件名:");
  24. scanf("%s",&File);
  25. int linecount=0;
  26. linecount=LineCount(File);
  27. printf("文件的行数为:%d\n",linecount);
  28. continue;
  29. }
  30. if(input[0]=='a'){
  31. printf("请输入文件名:");
  32. scanf("%s",&File);
  33. ComplexCount(File);
  34. continue;
  35. }
  36. }
  37. system("pause");
  38. return 0;
  39. }

 

 

主函数:运用传参的方法

  1. int CharCount(char file[]){//字符数统计函数
  2. FILE *pf=NULL;
  3. int ccount=0;
  4. pf=fopen(file,"r");
  5. if(pf==NULL){
  6. printf("寻找文件失败\n");
  7. exit(-1);
  8. }
  9. char mychar;
  10. mychar = fgetc(pf);
  11. while(mychar!=EOF){
  12. mychar = fgetc(pf);
  13. ccount++;
  14. }
  15. fclose(pf);
  16. return ccount;
  17. }

字符统计函数:在每次读取文件中的字符时,ccount+1

  1. int WordCount(char file[]){//单词数统计函数
  2. FILE *pf=NULL;
  3. int wcount=0;
  4. pf=fopen(file,"r");
  5. if(pf==NULL){
  6. printf("寻找文件失败\n");
  7. exit(-1);
  8. }
  9. char mychar;
  10. mychar = fgetc(pf);
  11. while(mychar!=EOF){
  12. if(mychar>='a'&&mychar<='z'||mychar>='A'&&mychar<='Z'||mychar>='0'&&mychar<='9'){
  13. while(mychar>='a'&&mychar<='z'||mychar>='A'&&mychar<='Z'||mychar>='0'&&mychar<='9'||mychar=='_'){
  14. mychar=fgetc(pf);
  15. }
  16. wcount++;
  17. mychar=fgetc(pf);
  18. }
  19. mychar=fgetc(pf);
  20. }
  21. fclose(pf);
  22. return wcount;
  23. }

 

单词统计函数

  1. int LineCount(char file[]){//行数统计函数
  2. FILE *pf=NULL;
  3. int lcount=0;
  4. pf=fopen(file,"r");
  5. if(pf==NULL){
  6. printf("寻找文件失败\n");
  7. exit(-1);
  8. }
  9. char mychar;
  10. mychar = fgetc(pf);
  11. while(mychar!=EOF){
  12. if(mychar=='\n'){
  13. lcount++;
  14. mychar = fgetc(pf);
  15. }
  16. else{
  17. mychar = fgetc(pf);
  18. }
  19. }
  20. fclose(pf);
  21. return lcount+1;
  22. }

 

行数统计函数

  1. int ComplexCount(char file[]){
  2. FILE *pf=NULL;
  3. int spacecount=0;
  4. pf=fopen(file,"r");
  5. if(pf==NULL){
  6. printf("寻找文件失败\n");
  7. exit(-1);
  8. }
  9. char mychar;
  10. mychar = fgetc(pf);
  11. while(mychar!=EOF){
  12. if(mychar=='\n'){
  13. mychar=fgetc(pf);
  14. if(mychar=='\n' ){
  15. spacecount++;
  16. mychar=fgetc(pf);
  17. }
  18. }
  19. else if(mychar=='}'){
  20. mychar=fgetc(pf);
  21. if(mychar=='\n'){
  22. spacecount++;
  23. mychar=fgetc(pf);
  24. }
  25. }
  26. else mychar=fgetc(pf);
  27. }
  28. printf("文件空行数为%d\n",spacecount);
  29. return 0;
  30. }

空行统计函数:该算法有缺陷,不严谨

测试结果

                    

              

PSP

PSP2.1

Personal Software Process Stages

预估耗时(分钟)

实际耗时(分钟)

Planning

计划

30

30

· Estimate

· 估计这个任务需要多少时间

24*60

2*24*60

Development

开发

10*60

12*60

· Analysis

· 需求分析 (包括学习新技术)

15

10

· Design Spec

· 生成设计文档

5

5

· Design Review

· 设计复审 (和同事审核设计文档)

10

10

· Coding Standard

· 代码规范 (为目前的开发制定合适的规范)

15

15

· Design

· 具体设计

30

60

· Coding

· 具体编码

5*60

5*60

· Code Review

· 代码复审

15

30

· Test

· 测试(自我测试,修改代码,提交修改)

15

15

Reporting

报告

20

30

· Test Report

· 测试报告

15

20

· Size Measurement

· 计算工作量

10

10

· Postmortem & Process Improvement Plan

· 事后总结, 并提出过程改进计划

15

15

合计

 

2535

4150

 

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号