Go语言实现统计字符串中每个字符出现的次数

文章主要为大家详细介绍了如何使用Go语言开发一个简易频率分析器,实现统计字符串中每个字符出现的次数,感兴趣的小伙伴可以了解一下。

一、 案例目标

本案例将实现一个程序,接收用户输入的一段文字,并统计其中每个字符(包括中文、英文、数字等)出现的次数,并按字符输出。

例如输入:

Hello, 世界!

输出:

H: 1
e: 1
l: 2
o: 1
,: 1
 : 1
世: 1
界: 1
!: 1

二、 应用场景举例

  • 文本分析、关键词提取
  • 字符频率统计(用于密码分析、数据挖掘)
  • 字符画处理(字符权重)
  • AI、自然语言处理基础任务之一

三、 涉及知识点讲解

知识点 说明
map[rune]int Go 中用于统计频率的典型用法
rune 支持 Unicode 字符(中文、表情、特殊符号)
for _, r := range str 正确遍历字符串每个字符(而不是每个字节)

四、实现需求

  • 用户输入任意一段文字;
  • 程序逐个字符统计出现次数;
  • 忽略字节编码问题,支持中文;
  • 输出格式整齐,便于查看;
  • 可拓展成图表/词云工具基础。

五、 完整代码实现

package main
 
import (
    "bufio"
    "fmt"
    "os"
    "sort"
)
 
func main() {
    reader := bufio.NewReader(os.Stdin)
    fmt.Print("请输入一段文字:")
    input, _ := reader.ReadString('\n')
 
    counts := countCharacters(input)
 
    // 排序输出
    var keys []rune
    for k := range counts {
        keys = append(keys, k)
    }
    sort.Slice(keys, func(i, j int) bool {
        return keys[i] < keys[j]
    })
 
    fmt.Println("\n字符统计结果:")
    for _, r := range keys {
        fmt.Printf("%q: %d\n", r, counts[r])
    }
}
 
// 统计字符出现次数
func countCharacters(s string) map[rune]int {
    result := make(map[rune]int)
    for _, r := range []rune(s) {
        result[r]++
    }
    return result
}

六、运行示例

示例1:

请输入一段文字:hello, 世界

字符统计结果:
'\t': 1
',': 1
'e': 1
'h': 1
'l': 2
'o': 1
'世': 1
'界': 1
'\n': 1

'\n' 和 '\t' 说明:默认输入带有换行符,可根据需要清洗。

七、 核心代码解析

代码段 说明
map[rune]int 创建一个以字符为键、出现次数为值的映射
[]rune(s) 将字符串转为字符切片,避免中文字符拆分错误
sort.Slice 将输出结果按字符顺序排序

八、 拓展练习建议

  • 排除空格或标点,只统计字母与数字;
  • 将结果写入文件保存;
  • 改为支持词语统计(用 strings.Fields() 分词);
  • 输出词频图或柱状图(结合 github.com/olekukonko/tablewriter 或 ASCII 图表库);

九、 常见错误提示

  • 遍历字符串用 []byte:会导致中文字符被拆成多个 byte;
  • 统计字符时忘记使用 rune 类型;
  • 输出结果不排序,阅读困难。

小结

通过这个案例,你学会了:

  • 如何遍历字符串中每一个字符(支持中文)
  • 如何使用 map 来进行频率统计
  • 如何对统计结果进行排序并美观输出

这是实际项目中非常有价值的一种“文本特征提取”技术,是通往 NLP 和算法世界的一扇小门。

到此这篇关于Go语言实现统计字符串中每个字符出现的次数的文章就介绍到这了,更多相关Go统计字符内容请继续浏览下面的相关文章!