1 回答
TA贡献1797条经验 获得超4个赞
您不需要将 JSON 对象包装到数组中,您可以按原样编写它们。您可以用来json.Encoder
将它们写入文件,也可以用来json.Decoder
读取它们。Encoder.Encode()
并对Decoder.Decode()
流中的各个 JSON 值进行编码和解码。
为了证明它有效,请看这个简单的例子:
const src = `{"id":"1"}{"id":"2"}{"id":"3"}`
dec := json.NewDecoder(strings.NewReader(src))
for {
var m map[string]interface{}
if err := dec.Decode(&m); err != nil {
if err == io.EOF {
break
}
panic(err)
}
fmt.Println("Read:", m)
}
它输出(在Go Playground上试试):
Read: map[id:1] Read: map[id:2] Read: map[id:3]
写入文件/从文件读取时,将os.File
tojson.NewEncoder()
和json.NewDecoder()
.
这是一个完整的演示,它创建一个临时文件,用于json.Encoder
将 JSON 对象写入其中,然后使用以下命令读回它们json.Decoder
:
objs := []map[string]interface{}{
map[string]interface{}{"id": "1"},
map[string]interface{}{"id": "2"},
map[string]interface{}{"id": "3"},
}
file, err := ioutil.TempFile("", "test.json")
if err != nil {
panic(err)
}
// Writing to file:
enc := json.NewEncoder(file)
for _, obj := range objs {
if err := enc.Encode(obj); err != nil {
panic(err)
}
}
// Debug: print file's content
fmt.Println("File content:")
if data, err := ioutil.ReadFile(file.Name()); err != nil {
panic(err)
} else {
fmt.Println(string(data))
}
// Reading from file:
if _, err := file.Seek(0, io.SeekStart); err != nil {
panic(err)
}
dec := json.NewDecoder(file)
for {
var obj map[string]interface{}
if err := dec.Decode(&obj); err != nil {
if err == io.EOF {
break
}
panic(err)
}
fmt.Println("Read:", obj)
}
它输出(在Go Playground上试试):
File content:
{"id":"1"}
{"id":"2"}
{"id":"3"}
Read: map[id:1]
Read: map[id:2]
Read: map[id:3]
- 1 回答
- 0 关注
- 144 浏览
添加回答
举报