201671030109 词频统计软件项目报告
|项目|内容
:--|:--|:--|:--|:--|:--|:--|:--|
|这个作业属于哪个课程|任课教师博客主页链接
|这个作业的要求在哪里|作业链接地址
|课程学习目标| (1)掌握软件项目个人开发流程。(2)掌握Github上发布软件项目的操作方法。
|本次作业在哪个具体方面帮助我们实现目标| 第一次体验个人项目
需求分析:
尝试按照《构建之法》第2章中2.3所述PSP流程,使用JAVA编程语言,独立完成一个英文文本词频统计的软件开发。软件基本功能要求如下:
1.程序可读入任意英文文本文件,该文件中英文词数大于等于1个。
2.程序需要很壮健,能读取容纳英文原版《哈利波特》10万词以上的文章。
3.指定单词词频统计功能:用户可输入从该文本中想要查找词频的一个或任意多个英文单词,运行程序的统计功能可显示对应单词在文本中出现的次数和柱状图。
4.高频词统计功能:用户从键盘输入高频词输出的个数k,运行程序统计功能,可按文本中词频数降序显示前k个单词的词频及单词。
5.统计该文本所有单词数量及词频数,并能将单词及词频数按字典顺序输出到文件result.txt。
功能设计:
1、读文本功能——读入文本数据
2、用户输入功能——输入用户想要查询的单词以及想要查询高频单词的个数
3、排序功能——降序排序和按字典顺序排序
4、词频统计功能——显示输入单词在文本中出现的次数和柱状图以及降序显示前k个单词的词频及单词
5、写文件功能——将输出数据存入文件中
设计实现:
具体设计如下:
-main.java 控制整个程序
<1、实现对文本文件中数据的读入
<2、对各项功能进行选择,并调用wordcount.java中相应的函数实现各项功能
-wordcount.java 包括四个功能函数:
<1、显示词频和柱状图——输入从该文本中想要查找词频的一个或任意多个英文单词,显示对应单词在文本中出现的次数和柱状图。
<2、输出高频词——按文本中词频数降序显示前k个单词的词频及单词。
❤️、排序——降序排序和按字典顺序排序
<4、写文件——将文本中所有单词数量及词频数按字典顺序输出到文件result.txt中
关键代码:
// 词频统计界面
System.out.println("***************英文文本词频统计软件****************");
System.out.println("请选择你需要实现的功能序号:");
System.out.println("1、读取文本");
System.out.println("2、显示所要查询的单词词频");
System.out.println("3、输出词频最高的前k个单词");
System.out.println("4、统计该文本所有单词数量及词频数,并将单词及词频数按字典顺序输出到文件result.txt");
System.out.println("0、退出");
System.out.println("*****************************************************"); ```
//输出前k个高频词
void HighWord(Map<String, Integer> map) {
sort(map,2);//先利用上一个方法sort()来对统计好的单词按单词出现的频数排序,然后再进行前k个单词的选取
System.out.println("请输入查看单词个数:");
int k = in.nextInt();
for(Entry<String,Integer> y : Map.entrySet()) {
System.out.println("单词——"+y.getKey() + " 出现" + y.getValue()+"次");
k--;
if(k<=0)
break;
}
}
//将结果存入文件中result.txt
void output(Map<String, Integer> map)throws IOException {
sort(map,3);
File file = new File("result.txt");//创建一个新的文件
FileWriter f = new FileWriter(file.getAbsoluteFile());//调用了getAbsoluteFile()方法
for(Entry<String,Integer> y: Map.entrySet()) {
f.write(y.getKey() + ":" + y.getValue()+" ");
}
f.close();//关闭文件
System.out.println("成功写入result文件中!");
测试运行:
程序的运行截图如下:
result.txt中部分结果如下图:
总结:设计的程序如何实现软件设计的“模块化”原则
在本次词频统计软件项目中创建了两个类:Main类控制整个程序,读入文本文件中的数据,显示所要选择的执行菜单并调用wordcount类中的各个函数。wordcount类中包含四个函数:histogram函数s实现显示词频和柱状图的功能、HighWord函数显示输出高频词得功能、sort函数实现降序排序和按字典顺序排序的功能、output函数是将结果输出到文件result.txt中,各个部分分别实现各自的功能,并相互联系实现整个软件项目。
项目开发过程中,构建PSP表如下:
|PSP|任务内容|计划共完成需要的时间(min)|实际完成需要的时间(min)
:--|:--|:--|:--|:--|:--|:--|:--|
|Planning| 计划 |10|15
|- Estimate|估计这个任务需要多少时间,并规划大致工作步骤|10|15
|Development| 开发|280|340
|- Analysis| 需求分析 (包括学习新技术)|15|25
|- Design Spec| - 生成设计文档|20|25
|- Design Review| - 设计复审 (和同事审核设计文档)|20|15
|- Coding Standard| 代码规范 (为目前的开发制定合适的规范)|15|20
|- Design| 具体设计|40|50
|- Coding|具体编码|150|180
|- Test| - 测试(自我测试,修改代码,提交修改)|20|25
|Reporting|报告|50|48
|-- Test Report| - 测试报告|25|20
|- Size Measurement| 计算工作量|25|28
|- Postmortem & Process Improvement Plan|- 事后总结 ,并提出过程改进计划|30|28
在本次软件项目开发过程中,在需求分析以及具体代码编辑阶段计划时间与实际完成时间误差较大,主要还是因为编程不过关,对Java程序的编写掌握的并不是很好;在刚开始时,并没有对需求进行充分的分析,导致功能实现不全面,如只实现了统计对应单词出现的次数,但并不能用柱状图显示;所以,在以后的学习过程中我应该注意仔细进行相关项目的需求分析,并应具备一定的编程能力,才能更好地完成项目。