Map 对golang中的结构图进行排序

Map 对golang中的结构图进行排序,map,go,Map,Go,我有一张这样的地图 Key: 9970DLXEVOQ0O Value: [{9972IOFNIDER6 0.3},{9972MFYWYJIEK 0.2},{9972QIUUINW6R 0.5}] Key: 9970DLXEVOQ01 Value: [{9972IOFNIDER6 0.3}] Key: 9970QYPOYUUIO Value: [{9972VOFA3OJLK 0.4}] 在名为产品的golang中,交易,其中键为字符串,值为结构: type product_detail stru

我有一张这样的地图

Key: 9970DLXEVOQ0O Value: [{9972IOFNIDER6 0.3},{9972MFYWYJIEK 0.2},{9972QIUUINW6R 0.5}]
Key: 9970DLXEVOQ01 Value: [{9972IOFNIDER6 0.3}]
Key: 9970QYPOYUUIO Value: [{9972VOFA3OJLK 0.4}]
在名为产品的golang中,交易,其中为字符串,为结构:

type product_detail struct {
     deal_id string
     rating float64
}
我需要根据每个输出值字段中的评级(降序)对值进行排序,即

Key: 9970DLXEVOQ0O Value: [{9972QIUUINW6R 0.5},{9972IOFNIDER6 0.3},{9972MFYWYJIEK 0.2}]
Key: 9970DLXEVOQ01 Value: [{9972IOFNIDER6 0.3}]
Key: 9970QYPOYUUIO Value: [{9972VOFA3OJLK 0.4}]
任何关于如何做到这一点的想法。我确实看过另一篇对地图进行排序的文章,但没有得到实现。
如果有任何帮助,我们将不胜感激。

为了进一步阐述我对原始问题的看法,这里有一个可以在计算机上运行的工作示例。请注意,我可能误解了您想要的类型的结构,但是想法应该很清楚

package main

import "fmt"
import "sort"

type Product struct {
    Id     string
    Rating float64
}

type Deal struct {
    Id       string
    products []Product
}

type Deals []Deal

// Ensure it satisfies sort.Interface
func (d Deals) Len() int           { return len(d) }
func (d Deals) Less(i, j int) bool { return d[i].Id < d[j].Id }
func (d Deals) Swap(i, j int)      { d[i], d[j] = d[j], d[i] }

func main() {
    deals := Deals{
        {"9970DLXEVOQ0O", []Product{{"9972MFYWYJIEK", 0.2}}},
        {"9970DLXEVOQ01", []Product{{"9972IOFNIDER6", 0.3}}},
        {"9970QYPOYUUIO", []Product{{"9972VOFA3OJLK", 0.4}}},
        {"9970DLYKLAO8O", []Product{{"9972IOFNIDER6", 0.3}}},
        {"9970QYPMNAUUI", []Product{{"9972QIUUINW6R", 0.5}}},
    }

    sort.Sort(deals)

    for _, d := range deals {
        fmt.Println(d)
    }
}
主程序包
输入“fmt”
导入“排序”
类型产品结构{
Id字符串
评级浮动64
}
类型交易结构{
Id字符串
产品[]产品
}
输入Deals[]交易
//确保它满足sort.Interface
func(d)Len()int{return Len(d)}
func(d Deals)Less(i,j int)bool{return d[i].Id
Go中的地图本质上是无序的数据结构。无法保证同一映射的两个不同迭代之间的顺序相同。插入一个新值可能会改变这一切。如果需要排序,则必须使用切片或数组。应该注意的是,这并不是Go的map实现的缺点。这只是哈希表的一个特征。那么我们需要覆盖切片的排序方法吗?默认情况下,切片没有排序方法。您可以定义类似于
type Deals[]*product\u deal
的内容,并确保它实现了
sort.Interface
()的所有方法。然后你可以在上面调用
sort.sort(myslice)
。谢谢你的回答,我忘了提到我需要根据评级(降序)排序。另外,我对我的实现做了一点更改,我将编辑问题并在那里提及。通过更改
交易的实现,这很容易做到。更少的
。逻辑更改后,实现是否仍保持不变。是的。唯一的区别是,列表然后按评级而不是Id排序。