201671010425-邱世妍 词频统计软件项目报告
github地址:https://github.com/qsy960415/zuoye
1.需求分析
1.程序可读入任意英文文本文件,该文件中英文词数大于等于1个。
2.程序需要很壮健,能读取容纳英文原版《哈利波特》10万词以上的文章。
3.指定单词词频统计功能:用户可输入从该文本中想要查找词频的一个或任意多个英文单词,运行程序的统计功能可显示对应单词在文本中出现的次数和柱状图。
4.高频词统计功能:用户从键盘输入高频词输出的个数k,运行程序统计功能,可按文本中词频数降序显示前k个单词的词频及单词。
5.统计该文本所有单词数量及词频数,并能将单词及词频数按字典顺序输出到文件result.txt。
2.功能设计
2.1 基本功能
1.能够读取txt文件
2.能够统计出txt文件中单词出现的频率
2.2 扩展功能:
可以将出现的单词进行排序,按照出现的频率进行排序,按照降序进行排序。
3.设计实现
使用java语言对程序进行设计
1.先要读取要进行查询的文件
2.然后对读取的文件里的单词进行统计
3.然后对统计出来的单词进行排序输出
4.测试运行
5.代码精选
6.总结
在此次实验中运用了java进行编写了词频统计软件,并对统计的词频按照出现频率进行了排序,在此次实验中出现了好多错误,通过百度对出现的错误进行了查询,修改自己的代码,一次次的修改,对我的java编程能力进一步的提高,对统计函数和排序函数进一步加深了理解,通过此次试验,我还发现了我的代码量不足,以后还需要多加练习、编写java程序来提高我的编程能力。
7.PSP
PSP2.1 | 任务内容 | 计划共完成需要的时间(min) | 实际完成需要的时间(min) |
---|---|---|---|
Planning | 计划 | 5 | 10 |
Estimate | 估计这个任务需要多少时间,并规划大致工作步骤 | 10 | 8 |
Development | 开发 | 180 | 150 |
Analysis | 需求分析 (包括学习新技术) | 10 | 5 |
Design Spec | 生成设计文档 | 10 | 20 |
Design Review | 设计复审 (和同事审核设计文档) | 10 | 5 |
Coding Standard | 代码规范 (为目前的开发制定合适的规范) | 30 | 20 |
Design | 具体设计 | 30 | 60 |
Coding | 具体编码 | 60 | 120 |
Code Review | 代码复审 | 10 | 20 |
Test | 测试(自我测试,修改代码,提交修改 | 5 | 10 |
Reporting | 报告 | 10 | 10 |
Test Report | 测试报告 | 10 | 10 |
Size Measurement | 计算工作量 | 10 | 15 |
Postmortem & Process Improvement Plan | 事后总结 ,并提出过程改进计划 | 20 | 25 |