JAVA【词频统计】笔记

词频统计

  • 参看本博《经典案例【词频统计】十一种实现方式》
  • 针对单词文本文件,统计每个单词出现的次数
hello hadoop hello spark
i love you hadoop and spark
i learn hadoop and scala
思路:读取文件,通过拆分得到单词数组,定义一个哈希映射保存词频统计结果,遍历单词数组,如果第一次遇到某个单词,就在哈希映射里添加一个元素,单词为键,1为值;如果不是第一次遇到,那么在哈希映射里找到该键,将其值加1……

(一)编程实现

  • 在项目根目录里创建单词文本文件 - words.txt
    在这里插入图片描述
  • net.nieyourong.p03里创建t08子包,在子包里创建WordCount
    在这里插入图片描述
  • 读取文件所有行
    在这里插入图片描述
  • 将文件行按空格拆分成单词数组
    在这里插入图片描述
  • 针对每行单词数组进行词频统计
    在这里插入图片描述
  • 按指定格式输出词频统计结果
    在这里插入图片描述
  • 利用Python的绘图库来绘制词频统计的直方图
    在这里插入图片描述
  • 查看完整代码
package net.nieyourong.p03.t08;

import java.io.BufferedReader;
import java.io.FileReader;
import java.util.HashMap;
import java.util.Map;

/**
 * 功能:词频统计
 * 作者:聂友蓉
 * 日期:2022年06月09日
 */
public class WordCount {
    public static void main(String[] args) throws Exception {
        //定义缓冲字符输入流
        BufferedReader br =new BufferedReader(new FileReader("words"));
        //定义词频统计哈希映射
        Map<String,Integer> wc = new HashMap<>();
        //定义行字符串变量
        String nextLine = "";
        //读取文件,遍历所有行
        while ((nextLine = br.readLine()) != null) {
            //按空格拆分,得到单词数组
            String[] words = nextLine.split(" ");
            //遍历单词数组,进行单词计数
            for (String word : words) {
                wc.put(word,wc.containsKey(word)? wc.get(word) + 1 : 1);
            }
        }
        //按照指定格式输出词频统计结果
        for (String key : wc.keySet()) {
            System.out.println("(" + key + "," + wc.get(key) + ")");
        }
    }
}

思考题:将词频统计结果按次数降序排列

(二)知识点讲解

1、哈希映射
  • put(key, value) - 添加元素(键值对)
  • get(key) - 按键取值
  • containsKey(key) - 是否包含某个键
  • keySet() - 键集合
  • values() - 值集合
2、哈希集合
  • add(e) - 添加元素
  • remove(e) - 移除元素
  • size() - 集合元素个数
  • isEmpty() - 是否为空集

(三)拓展练习

任务1、网址去重
  • 去掉重复ip地址,生成distinct_ips.txt
    在这里插入图片描述
任务2、统计不同网址访问次数

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值