Word Count(C语言)
1.项目地址
https://github.com/namoyuwen/word-count
2.项目相关要求
2.1 项目描述
Word Count
1. 实现一个简单而完整的软件工具(源程序特征统计程序)。
2. 进行单元测试、回归测试、效能测试,在实现上述程序的过程中使用相关的工具。
3. 进行个人软件过程(PSP)的实践,逐步记录自己在每个软件工程环节花费的时间。
2.2 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 文件的代码行数、空行数、注释行数。
3.解题思路描述
1.首先拿到这个题目,由于只对C语言熟悉,故想着用C语言去做,而C语言的使用已经有一段啥时间没用了,所以在重新熟悉的时间上花费了较多的时间
2.在网上学习这个文件的操作难点和关键点的时候,这个题目的一个重点是对于文件操作,对于文件的操作也进行学习
3.这个题目主要分为4个模块,主函数模块,和三个基本功能模块
4.设计实现过程。
1.先写出三个子函数,统计字数,单词数和行数
2.主函数调用这三个函数
5.代码说明。
1.主函数
#include<stdio.h>
#include<stdlib.h>
int charc(char *file);
int wordc(char *file);
int linec(char *file);
int main(){
FILE *fp;
int ch,wo,li;
char file[50];//文件地址
printf("\n请输入文件地址:\n");
scanf("%s",file);
if((fp=fopen(file,"r"))==NULL)
{
printf("不存在这个文件");
exit(-1);
}
else{
ch=charc(file);
wo=wordc(file);
li=linec(file);
printf("\n该文件字符数为%d\n单词数为%d\n行数为%d\n",ch,wo,li);
}
}
2.字符数统计
int charc(char *file) {
FILE *fp = NULL;
int charcount = 0;
if ((fp=fopen(file,"r"))== NULL) {
printf("文件寻找失败!\n");
exit(-1);
}
char ch;
ch = fgetc(fp);
while (!feof(fp)) {
ch = fgetc(fp);//读取文件中的字符
charcount++;//统计字符数
}
fclose(fp);
return charcount;
}
3.单词数统计
int wordc(char *file) {
FILE *fp = NULL;
int wordcount = 0;
if ((fp = fopen(file,"r")) == NULL) {
printf("文件寻找失败!\n");
exit(-1);
}
char ch;
int word;
while (!feof(fp)) {
ch = fgetc(fp);
if (ch<'A' || (ch> 'Z'&&ch< 'a') || ch>'z')
{
word = 0;
}
else if (word == 0)
{
word = 1;
wordcount++;
}
}
return wordcount;
}
4.行数统计
int linec(char *file){//计算行数
int linecount=0;
char ch,li=0;
FILE *fp;
if ((fp=fopen(file,"r"))==NULL)
{
exit(-1);
}
ch = fgetc(fp);
while (!feof(fp))
{
if(ch=='\n')
linecount++;
li=ch;
}
if (li!='\n')
linecount++;
return linecount;
}
6.测试运行。
1.空文件
2.一个词文件
3.一行文件
4.一个典型源文件
7.项目小结。
这次的个人项目,花了较长的时间在复习C语言的过程上,同时也参考了许多人的资料与间接,发现了自己在C语言上还有许多的不足,同时在编码时想法也很混乱,基本考虑不到重要的点。
这次的项目让自己意识到了还存在许多的不足,革命尚未完成,同志仍须努力。我还需要每天花费时间在对语言的学习上,掌握更多的知识。而这次PSP表自己的实际耗时也比预估长了许多
,主要是在于对代码的不熟练以及在学习上花了许多时间。
| PSP | Personal Software Process Stages | 预估耗时(分钟) | 实际耗时(分钟) |
|---|---|---|---|
| Planning | 计划 | 50 | 75 |
| · Estimate | 估计这个任务需要多少时间 | 20 | 15 |
| Development | 开发 | 120 | 150 |
| Analysis | 需求分析 (包括学习新技术) | 30 | 120 |
| ·Design Spec | 生成设计文档 | 20 | 30 |
| ·Design Review | 设计复审 (和同事审核设计文档) | 0 | 0 |
| · Coding Standard | 代码规范 (为目前的开发制定合适的规范) | 5 | 5 |
| ·Design | 具体设计 | 30 | 60 |
| ·Coding | 具体编码 | 100 | 160 |
| ·Code Review | 代码复审 | 30 | 45 |
| ·Test | 测试(自我测试,修改代码,提交修改) | 10 | 5 |
| Reporting | 报告 | 10 | 30 |
| ·Test Report | 测试报告 | 10 | 10 |
| ·Size Measurement | 计算工作量 | 30 | 60 |
| ·Postmortem & Process Improvement Plan | 事后总结, 并提出过程改进计划 | 20 | 30 |
| 合计 | 485 | 795 | |
Word Count(C语言)的更多相关文章
- Word Count作业
Word Count作业 一.个人Gitee地址:https://gitee.com/Changyu-Guo 二.项目简介 该项目主要是模拟Linux上面的wc命令,基本要求如下: 命令格式: wc. ...
- Word Count
Word Count 一.个人Gitee地址:https://gitee.com/godcoder979/(该项目完整代码在这里) 二.项目简介: 该项目是一个统计文件字符.单词.行数等数目的应用程序 ...
- 课堂练习 Word count
1. 团队介绍 团队成员:席梦寒,胡琦 2. 项目计划 我们选第一.二个功能点进行编程. 具体计划: (1).首先爬取网站内容及网页长度: (2).对爬取的文件内容进行word count操作: 3. ...
- 个人项目作业-Word Count
个人项目作业 1.Github地址 https://github.com/CLSgGhost/SE_work 2.项目相关需求 wc.exe 是一个常见的工具,它能统计文本文件的字符数.单词数和行数. ...
- Hive Word count
--https://github.com/slimandslam/pig-hive-wordcount/blob/master/wordcount.hql DROP TABLE myinput; DR ...
- mac上eclipse上运行word count
1.打开eclipse之后,建立wordcount项目 package wordcount; import java.io.IOException; import java.util.StringTo ...
- MapReduce工作机制——Word Count实例(一)
MapReduce工作机制--Word Count实例(一) MapReduce的思想是分布式计算,也就是分而治之,并行计算提高速度. 编程思想 首先,要将数据抽象为键值对的形式,map函数输入键值对 ...
- [Hive_add_6] Hive 实现 Word Count
0. 说明 Hive 通过 explode()函数 和 split()函数 实现 WordConut 1. Hive 实现 Word Count 方式一 1.1 思路 将每一行文本变为 Array 数 ...
- Mac下hadoop运行word count的坑
Mac下hadoop运行word count的坑 Word count体现了Map Reduce的经典思想,是分布式计算中中的hello world.然而博主很幸运地遇到了Mac下特有的问题Mkdir ...
随机推荐
- AI大厂算法测试心得:人脸识别关键指标有哪些?
仅仅在几年前,程序员要开发一款人脸识别应用,就必须精通算法的编写.但现在,随着成熟算法的对外开放,越来越多开发者只需专注于开发垂直行业的产品即可. 由调查机构发布的<中国AI产业地图研究> ...
- Python第一次实验
''' 计算 1.输入半径,输出面积和周长 2.输入面积,输出半径及周长 3.输入周长,输出半径及面积 ''' # # 1.输入半径,输出面积和周长 # from math import pi # # ...
- GitHub 热点速览 Vol.30:那些提升效率的小工具们
摘要:虽然 GitHub 是一个学习技术的好去处,但是除了学习,它还集提高"搬砖"效率于一身.GitHub 上散落着各式各样的小工具,比如本周特推的 Adobe 开源的 React ...
- Python os.tmpnam() 方法
概述 os.tmpnam() 方法用于为创建一个临时文件返回一个唯一的路径.高佣联盟 www.cgewang.com 语法 tmpnam()方法语法格式如下: os.tmpnam 参数 无 返回值 返 ...
- Spark Streaming高吞吐、高可靠的一些优化
分享一些Spark Streaming在使用中关于高吞吐和高可靠的优化. 目录 1. 高吞吐的优化方式 1.1 更改序列化的方式 1.2 修改Receiver接受到的数据的存储级别 1.3 广播配置变 ...
- 浅析BST二叉搜索树
2020-3-25 update: 原洛谷日报#2中代码部分出现一些问题,详情见此帖.并略微修改本文一些描述,使得语言更加自然. 2020-4-9 update:修了一些代码的锅,并且将文章同步发表于 ...
- C++ 中可调用的且有函数功能的东东
第一个:函数 其实函数在声明的时候都有个名字: 这个名字可以看作是是指针,将其直接赋值给函数指针 也可以看作是可取指的对其& 再赋值给函数指针 第二个:函数指针 通过其被赋值的方式 ...
- 【CF600E】Lomset gelral 题解(树上启发式合并)
题目链接 题目大意:给出一颗含有$n$个结点的树,每个节点有一个颜色.求树中每个子树最多的颜色的编号和. ------------------------- 树上启发式合并(dsu on tree). ...
- ubuntu apt-get 安装找不到包问题
1.首先 sudo gedit /etc/apt/sources.list 删除全部换成国内源 (推荐163) 2.考虑 ubuntu apt-get update失败 1.出现错误:E:Could ...
- 比PS还好用!Python 20行代码批量抠图
你是否曾经想将某张照片中的人物抠出来,然后拼接到其他图片上去,从而可以即使你在天涯海角,我也可以到此一游? 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在 ...