我正在解析一个包含字符串数组的JSON对象:
var ii interface{}
json := "{\"aString\": [\"aaa_111\", \"bbb_222\"], \"whatever\":\"ccc\"}"
err := json.Unmarshal([]byte(json), &ii)
if err != nil {
log.Fatal(err)
}
data := ii.(map[string]interface{})
fmt.Println(data["aString"]) // outputs: ["aaa_111" "bbb_222"]
我尝试将data["aString"]
转换为[]字符串以便能够循环它,但它失败了:
test := []string(data["aString"]).([]string)
fmt.Println(test) // panic -> interface conversion:
// interface is string, not []string
如何转换data["aString"]
?
我没有正确表达自己。如果我打印data
,我就有这样的地图:
map[aString:["BBB-222","AAA-111"] whatever:ccc]
我想遍历aString(以操纵每个数组条目)。但我无法找到,因为aString是type interface {}
:
for i, v := range aString { // <-- fails
// ...
fmt.Println(i, v)
}
这就是我想转换aString的原因。我不想将看起来像数组的字符串转换为数组。
答案 0 :(得分:16)
我建议你放弃这个实现。您的json可能会有所不同,但您可以轻松使用对象并避免所有此类不安全的废话。
无论如何,转换不起作用,因为切片内的类型不是string
,它们也是interface{}
。您必须迭代集合,然后对每个项目执行类型断言,如下所示:
aInterface := data["aString"].([]interface{})
aString := make([]string, len(aInterface))
for i, v := range aInterface {
aString[i] = v.(string)
}
答案 1 :(得分:2)
这是你需要的吗?
package main
import (
"fmt"
"encoding/json"
)
func main() {
js := "{\"aString\": [\"aaa_111\", \"bbb_222\"], \"whatever\":\"ccc\"}"
a := make(map[string]interface{})
json.Unmarshal([]byte(js), &a)
for _, v := range a["aString"].([]interface{}) {
str := v.(string)
fmt.Println(str)
}
}
答案 2 :(得分:0)
对于另一种方法,您可以使用 struct
代替:
package main
import (
"encoding/json"
"fmt"
)
func main() {
s := []byte(`{"aString": ["aaa_111", "bbb_222"], "whatever":"ccc"}`)
var t struct {
Astring []string
Whatever string
}
json.Unmarshal(s, &t)
fmt.Printf("%+v\n", t) // {Astring:[aaa_111 bbb_222] Whatever:ccc}
}