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 | 正确遍历字符串每个字符(而不是每个字节) |
四、实现需求
- 用户输入任意一段文字;
- 程序逐个字符统计出现次数;
- 忽略字节编码问题,支持中文;
- 输出格式整齐,便于查看;
- 可拓展成图表/词云工具基础。
五、 完整代码实现
packagemainimport("bufio""fmt""os""sort")funcmain() {reader := bufio.NewReader(os.Stdin)fmt.("请输入一段文字:")input, _ := reader.ReadString('\n')counts := countCharacters(input)// 排序输出varkeys []runefork :=rangecounts {keys =append(keys, k)}sort.Slice(keys,func(i, jint)bool{returnkeys[i] < keys[j]})fmt.Println("\n字符统计结果:")for_, r :=rangekeys {fmt.Printf("%q: %d\n", r, counts[r])}}// 统计字符出现次数funccountCharacters(sstring)map[rune]int{result :=make(map[rune]int)for_, r :=range[]rune(s) {result[r]++}returnresult}
六、运行示例
示例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统计字符内容请继续浏览下面的相关文章!
您可能感兴趣的文章
声明:本文来自互联网或用户投稿,该文观点仅代表作者本人,不代表本站立场。文章及其配图仅供学习和交流之用,版权归原作者所有,如有内容侵权或者其他违规问题,请联系本站处理。


