201671030110词频统计软件项目报告

    做业           连接       
做业所属课程 西北师范大学软件工程
做业要求 实验二
源代码 Github

1.需求分析

  • 功能需求html

    (1).程序可读入任意英文文本文件,该文件中英文词数大于等于1个。
    (2).程序须要很壮健,能读取容纳英文原版《哈利波特》10万词以上的文章。
    (3).指定单词词频统计功能:用户可输入从该文本中想要查找词频的一个或任意多个英文单词,运行程序的统计功能可显示对应单词在文本中出现的次数和柱状图。
    (4).高频词统计功能:用户从键盘输入高频词输出的个数k,运行程序统计功能,可按文本中词频数降序显示前k个单词的词频及单词。
    (5).统计该文本全部单词数量及词频数,并能将单词及词频数按字典顺序输出到文件result.txt。git

  • 非功能需求github

    用户暂无界面等其余需求,不排除后期添加的可能性。算法

2.功能设计

  • 基本功能模块化

    (1)读入任意英文文本文件。
    (2)词频统计:用户输入文本当中单词,统计输出单词出现的次数和柱状统计图。
    (3)高频词频统计:用户输入个数K,按词频降序输出前K个单词的词频及单词。
    (4)统计该文本全部单词数量及词频数,按字典顺序输出单词及词频数到文件result.txt。函数

  • 扩展功能测试

    spa

3.设计实现

本软件的实现共有两个类:Main和Sort。
Main函数中主要是实现了菜单栏和词频统计的各个功能函数。.net

4.测试运行

4.1根据提示输入文本,根据菜单栏提示进行选择,选择功能1,查询输入的单词。以下为该单词不在文本当中时的状况。

4.2根据菜单栏提示进行选择,继续选择功能1,查询输入的单词。以下为该单词在文本当中时的状况。

4.3根据菜单栏提示进行选择,选择功能2,查询输入单词的词频。以下为词频为3时的状况。

4.4根据菜单栏提示进行选择,选择功能3,查询输入单词的词频。查询结果被写入文件result.txt.
设计

5.代码展现

boolean flag = false;
        for(int i = 0; i < word.length; i++) {
            for(Map.Entry<String,Integer> w : map.entrySet()) { 
                //int count=w.getValue();               
                if(word[i].equals(w.getKey()))
                {  
                    flag = true;
                        System.out.println("单词"+w.getKey() + "出现" + w.getValue()+"次");
                        sum=(float)(w.getValue())/50; 
                        for(int j = 0;j < sum; j++){
                            System.out.print("▓");
                        }   
                    }   
                } 
            if(!flag)
                System.out.println("单词"+word[i] + "不存在,请从新输入!");
                
            }       
    }

6.总结

对于软件开发的模块化我也是在此次项目的完成过程当中才体会到的,我在网上查阅了相关资料

模块化是指:

 1. 将大的个体分解成多个小的个体;
   实现这一步是我经过需求分析来总结用户想要的功能,将词频统计软件划分为一个一个小的功能来设计。
 2. 独立的、闭合的去分析处理这个个体和其与外界的关系。
   实现这一步是将每个功能单独拿出来分析,为它进行实现该功能的具体算法设计,除此以外还要有主函数来调用这些函数以实现这些功能。
 3.将这些个体组织、集成为一个新的大的个体;
   实现这一步则须要将每个功能函数和主函数相结合,构成一个主体便可。
 4. 持续的、迭代的进行这个过程直至解决问题。

7.展现PSP

相关文章
相关标签/搜索