网址: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语言相关知识
认识到需要不断巩固知识的重要性
关键代码及说明
- int main(){//主函数
- char input[10],File[200];
- while(1){
- printf("请输入用户命令:wc.exe-");
- scanf("%s",&input);
- if(input[0]=='c'){
- printf("请输入文件名:");
- scanf("%s",&File);
- int charcount=0;
- charcount=CharCount(File);
- printf("文件的字符数为:%d\n",charcount);
- continue;
- }
- if(input[0]=='w'){
- printf("请输入文件名:");
- scanf("%s",&File);
- int wordcount=0;
- wordcount=WordCount(File);
- printf("文件的词数为:%d\n",wordcount);
- continue;
- }
- if(input[0]=='l'){
- printf("请输入文件名:");
- scanf("%s",&File);
- int linecount=0;
- linecount=LineCount(File);
- printf("文件的行数为:%d\n",linecount);
- continue;
- }
- if(input[0]=='a'){
- printf("请输入文件名:");
- scanf("%s",&File);
- ComplexCount(File);
- continue;
- }
- }
- system("pause");
- return 0;
- }
主函数:运用传参的方法
- int CharCount(char file[]){//字符数统计函数
- FILE *pf=NULL;
- int ccount=0;
- pf=fopen(file,"r");
- if(pf==NULL){
- printf("寻找文件失败\n");
- exit(-1);
- }
- char mychar;
- mychar = fgetc(pf);
- while(mychar!=EOF){
- mychar = fgetc(pf);
- ccount++;
- }
- fclose(pf);
- return ccount;
- }
字符统计函数:在每次读取文件中的字符时,ccount+1
- int WordCount(char file[]){//单词数统计函数
- FILE *pf=NULL;
- int wcount=0;
- pf=fopen(file,"r");
- if(pf==NULL){
- printf("寻找文件失败\n");
- exit(-1);
- }
- char mychar;
- mychar = fgetc(pf);
- while(mychar!=EOF){
- if(mychar>='a'&&mychar<='z'||mychar>='A'&&mychar<='Z'||mychar>='0'&&mychar<='9'){
- while(mychar>='a'&&mychar<='z'||mychar>='A'&&mychar<='Z'||mychar>='0'&&mychar<='9'||mychar=='_'){
- mychar=fgetc(pf);
- }
- wcount++;
- mychar=fgetc(pf);
- }
- mychar=fgetc(pf);
- }
- fclose(pf);
- return wcount;
- }
单词统计函数
- int LineCount(char file[]){//行数统计函数
- FILE *pf=NULL;
- int lcount=0;
- pf=fopen(file,"r");
- if(pf==NULL){
- printf("寻找文件失败\n");
- exit(-1);
- }
- char mychar;
- mychar = fgetc(pf);
- while(mychar!=EOF){
- if(mychar=='\n'){
- lcount++;
- mychar = fgetc(pf);
- }
- else{
- mychar = fgetc(pf);
- }
- }
-
- fclose(pf);
- return lcount+1;
- }
行数统计函数
- int ComplexCount(char file[]){
- FILE *pf=NULL;
- int spacecount=0;
- pf=fopen(file,"r");
- if(pf==NULL){
- printf("寻找文件失败\n");
- exit(-1);
- }
- char mychar;
- mychar = fgetc(pf);
- while(mychar!=EOF){
- if(mychar=='\n'){
- mychar=fgetc(pf);
- if(mychar=='\n' ){
- spacecount++;
- mychar=fgetc(pf);
- }
- }
- else if(mychar=='}'){
- mychar=fgetc(pf);
- if(mychar=='\n'){
- spacecount++;
- mychar=fgetc(pf);
- }
- }
- else mychar=fgetc(pf);
- }
- printf("文件空行数为%d\n",spacecount);
- return 0;
- }
空行统计函数:该算法有缺陷,不严谨
测试结果


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
|