如何使用映射和键结构对 Go 中的结构切片进行分组和求和?
Go 中结构体切片的分组和求和
在分析数据时,经常需要将相似的元素分组在一起并计算聚合值每组。在 LINQ 中,可以使用内存中查询有效地实现这一点。 Go 提供了一种使用映射和闭包执行类似操作的通用方法。
考虑一个 Register 结构体切片,其中每个结构体包含多个唯一标识符(id1 到 id8)和一个整数值(金钱)。目标是按唯一标识符对这些寄存器进行分组,并对每组相应的货币值进行求和。
手动分组和求和:
一种方法是创建一个自定义 Equal 函数,用于根据标识符比较寄存器结构。然后,迭代切片,检查每个寄存器是否已存在于哈希表中。如果是,则货币价值增加。如果不是,则将一个新条目添加到包含寄存器和初始货币值 0 的哈希表中。
使用键结构和映射:
Go 的映射提供了一种更有效的方法来执行分组和求和操作。通过定义仅包含唯一标识符(id1 到 id8)的单独 Key 结构,您可以将其用作映射的唯一键。映射中的值可以是具有相同标识符组合的寄存器的货币值之和。
实现此方法:
- 定义 Key 和 Register 结构:
<code class="go">type Key struct { id1 int id2 int id3 int id4 int id5 int id6 int id7 int id8 int } type Register struct { key Key money int }</code>
- 使用 Key 作为键、初始货币值作为值来填充映射:
<code class="go">m := map[Key]int{}</code>
- 迭代寄存器,将它们添加到地图或更新其相应的货币值:
<code class="go">for _, v := range regs { m[v.key] += v.money }</code>
输出和格式:
为了更好地显示结果,您可以格式化其所有字段都以 id 为前缀的键结构。例如:
<code class="go">fmt.Println("Nice output:") for k, v := range m { fmt.Printf("%+3v: %d\n", k, v) }</code>
结论:
在 Go 中使用带有键结构的映射是一种高效且灵活的结构体切片分组和求和方法。它提供了手动分组和求和的高性能替代方案,特别是在处理大型数据集时。
以上是如何使用映射和键结构对 Go 中的结构切片进行分组和求和?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

OpenSSL,作为广泛应用于安全通信的开源库,提供了加密算法、密钥和证书管理等功能。然而,其历史版本中存在一些已知安全漏洞,其中一些危害极大。本文将重点介绍Debian系统中OpenSSL的常见漏洞及应对措施。DebianOpenSSL已知漏洞:OpenSSL曾出现过多个严重漏洞,例如:心脏出血漏洞(CVE-2014-0160):该漏洞影响OpenSSL1.0.1至1.0.1f以及1.0.2至1.0.2beta版本。攻击者可利用此漏洞未经授权读取服务器上的敏感信息,包括加密密钥等。

Go语言中用于浮点数运算的库介绍在Go语言(也称为Golang)中,进行浮点数的加减乘除运算时,如何确保精度是�...

Go爬虫Colly中的Queue线程问题探讨在使用Go语言的Colly爬虫库时,开发者常常会遇到关于线程和请求队列的问题。�...

本文讨论了GO编程中的GO FMT命令,该命令将代码格式化以遵守官方样式准则。它突出了GO FMT在维持代码一致性,可读性和降低样式辩论方面的重要性。 FO的最佳实践

后端学习路径:从前端转型到后端的探索之旅作为一名从前端开发转型的后端初学者,你已经有了nodejs的基础,...

本文介绍在Debian系统下监控PostgreSQL数据库的多种方法和工具,助您全面掌握数据库性能监控。一、利用PostgreSQL内置监控视图PostgreSQL自身提供多个视图用于监控数据库活动:pg_stat_activity:实时展现数据库活动,包括连接、查询和事务等信息。pg_stat_replication:监控复制状态,尤其适用于流复制集群。pg_stat_database:提供数据库统计信息,例如数据库大小、事务提交/回滚次数等关键指标。二、借助日志分析工具pgBadg
