golangマップを反復処理する


89

私はタイプの地図を持っています: map[string]interface{}

そして最後に、(goyamlを使用してymlファイルから逆シリアル化した後)次のようなものを作成します

mymap = map[foo:map[first: 1] boo: map[second: 2]]

このマップを反復処理するにはどうすればよいですか?私は以下を試しました:

for k, v := range mymap{
...
}

しかし、エラーが発生します:

cannot range over mymap
typechecking loop involving for loop

助けてください。


テストケースを提供することは可能ですか?投稿した内容から問題を診断するのは困難です。投稿した内容に固有のものがないため、型チェックループが発生する可能性があります。特に、関数本体で型チェックループを取得する方法を理解するのに苦労しています。
SteveMcQwark 2011年

回答:


107

例えば、

package main

import "fmt"

func main() {
    type Map1 map[string]interface{}
    type Map2 map[string]int
    m := Map1{"foo": Map2{"first": 1}, "boo": Map2{"second": 2}}
    //m = map[foo:map[first: 1] boo: map[second: 2]]
    fmt.Println("m:", m)
    for k, v := range m {
        fmt.Println("k:", k, "v:", v)
    }
}

出力:

m: map[boo:map[second:2] foo:map[first:1]]
k: boo v: map[second:2]
k: foo v: map[first:1]

4

あなたは一行でそれを作ることができます:

mymap := map[string]interface{}{"foo": map[string]interface{}{"first": 1}, "boo": map[string]interface{}{"second": 2}}
for k, v := range mymap {
    fmt.Println("k:", k, "v:", v)
}

出力は次のとおりです。

k: foo v: map[first:1]
k: boo v: map[second:2]

21
囲碁の言葉:賢くならないで、明確に。ワンライナーはGoの目標ではありません。
InancGumus19年

2

このように複数行で書き出すことができます。

$ cat dict.go
package main

import "fmt"

func main() {
        items := map[string]interface{}{
                "foo": map[string]int{
                        "strength": 10,
                        "age": 2000,
                },
                "bar": map[string]int{
                        "strength": 20,
                        "age": 1000,
                },
        }
        for key, value := range items {
                fmt.Println("[", key, "] has items:")
                for k,v := range value.(map[string]int) {
                        fmt.Println("\t-->", k, ":", v)
                }

        }
}

そして出力:

$ go run dict.go
[ foo ] has items:
        --> strength : 10
        --> age : 2000
[ bar ] has items:
        --> strength : 20
        --> age : 1000
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.