Go语言实战案例-统计文件中每个字母出现频率

以下是《Go语言100个实战案例》中的 文件与IO操作篇 - 案例19:统计文件中每个字母出现频率 的完整内容。本案例适合用来练习文件读取、字符处理、map统计等基础技能。

🎯 案例目标

读取一个本地文本文件,统计并打印出其中每个英文字母(忽略大小写)出现的次数和频率。


🧩 应用场景

  • • 文本分析、自然语言处理前的预处理
  • • 编写字频统计工具
  • • 简化数据分析或可视化处理的前置步骤

🧠 涉及知识点

  • • 使用 os.Open() 读取文件
  • bufio.Scanner 按行读取
  • • 字符串遍历与判断
  • • 使用 map[rune]int 统计频率
  • • 转换大小写 unicode.ToLower

💻 示例代码:统计字母频率

go 复制代码
package main

import (
    "bufio"
    "fmt"
    "os"
    "unicode"
)

func main() {
    filePath := "sample.txt"

    // 打开文件
    file, err := os.Open(filePath)
    if err != nil {
        fmt.Println("无法打开文件:", err)
        return
    }
    defer file.Close()

    // 用于存储每个字母出现的次数
    frequency := make(map[rune]int)
    totalLetters := 0

    scanner := bufio.NewScanner(file)
    for scanner.Scan() {
        line := scanner.Text()
        for _, ch := range line {
            if unicode.IsLetter(ch) {
                ch = unicode.ToLower(ch)
                frequency[ch]++
                totalLetters++
            }
        }
    }

    // 打印结果
    fmt.Println("字母频率统计:")
    for ch := 'a'; ch <= 'z'; ch++ {
        count := frequency[ch]
        if count > 0 {
            percentage := float64(count) / float64(totalLetters) * 100
            fmt.Printf("%c: %d (%.2f%%)\n", ch, count, percentage)
        }
    }
}

📂 示例文本内容(sample.txt)

vbnet 复制代码
Go is expressive, concise, clean, and efficient.
Its concurrency mechanisms make it easy to write programs.

📤 执行结果示例

erlang 复制代码
字母频率统计:
a: 5 (4.85%)
c: 7 (6.80%)
d: 2 (1.94%)
e: 10 (9.71%)
f: 2 (1.94%)
g: 1 (0.97%)
...
t: 8 (7.77%)
w: 1 (0.97%)

🛠 技术说明

函数 说明
os.Open() 打开文件
bufio.NewScanner() 按行扫描文本
unicode.IsLetter() 判断字符是否为英文字母
unicode.ToLower() 转换为小写字母以便统计统一
map[rune]int 使用字符为键的字典进行计数

🧪 拓展练习

  • • 统计所有字符(包括数字、标点)
  • • 按频率从高到低排序输出
  • • 将结果保存为 CSV 或 JSON 文件
  • • 添加参数选择分析哪个文件或字母范围(如大写、小写)

✅ 小结

这个案例帮助你掌握了如何在 Go 中进行文本分析,特别是字母频率统计。这是数据清洗和自然语言处理中的常见需求。


相关推荐
程序员小潘12 分钟前
Spring Gateway动态路由实现方案
后端·spring cloud
golang学习记16 分钟前
国内完美安装 Rust 环境 + VSCode 编写 Hello World 完整指南(2025 最新)
后端
Undoom24 分钟前
解锁超级生产力:手把手教你构建与GitHub深度集成的自动化工作流,让AI成为你的编程副驾驶
后端
我是华为OD~HR~栗栗呀41 分钟前
前端面经-高级开发(华为od)
java·前端·后端·python·华为od·华为·面试
菜鸟小九1 小时前
SSM(MybatisPlus)
java·开发语言·spring boot·后端
不爱编程的小九九1 小时前
小九源码-springboot051-智能推荐旅游平台
java·spring boot·后端
数据知道2 小时前
Go基础:常用数学函数处理(主要是math包rand包的处理)
开发语言·后端·golang·go语言
期待のcode2 小时前
MyBatis框架—延迟加载与多级缓存
java·数据库·后端·缓存·mybatis
数据知道2 小时前
Go基础:文件与文件夹操作详解
开发语言·后端·golang·go语言
华仔啊2 小时前
Spring 配置混乱?搞懂这两个核心组件,问题真能少一半
java·后端·spring