使用一個例子說明golang如何訪問和修改json文件;主要分三步:
- 從文件讀入json串
- 把json串轉(zhuǎn)變成golang對象
- 遍歷或者修改json值
- 寫回文件
假定用戶輸入json串為:
{
"user": {
"mspid": "admin",
"email": "admin@domain.com"
},
"nodes": [
{
"name": "node1",
"location": "node1.domain.com:8080"
},
{
"name": "node2",
"location": "node2.domain.com:8080"
}
]
}
我們的目標(biāo)是把node1和node2的location域換掉。
代碼如下
import (
"fmt"
"io/ioutil"
"encoding/json"
)
func HandleJson(jsonFile string, outFile string) error {
// Read json buffer from jsonFile
byteValue, err := ioutil.ReadFile(jsonFile)
if err != nil {
return err
}
// We have known the outer json object is a map, so we define result as map.
// otherwise, result could be defined as slice if outer is an array
var result map[string]interface{}
err = json.Unmarshal(byteValue, result)
if err != nil {
return err
}
// handle peers
nodes:= result["nodes"].([]interface{})
for _, node:= range node{
m := node.(map[string]interface{})
if name, exists := m["name"]; exists {
if name == "node1" {
m["location"] = "new-value1"
} else if name == "node2" {
m["location"] = "new-value2"
}
}
}
// Convert golang object back to byte
byteValue, err = json.Marshal(result)
if err != nil {
return err
}
// Write back to file
err = ioutil.WriteFile(outFile, byteValue, 0644)
return err
}
這個地方主要用的是golang的interface{}數(shù)據(jù)類型,然后把interface{}轉(zhuǎn)換成真正的數(shù)據(jù)類型。
這個函數(shù)可以擴(kuò)充成動態(tài)的解析任何類型,只要把所有的類型全部定義成interface{},然后使用動態(tài)類型檢測就可以知道每一個具體元素的類型了,最終達(dá)到類型jq的功能,訪問和修改json文件。
var x interface{} = ...
switch x.(type) {
case nil:
fmt.Println("x is nil")
case int:
fmt.Println("x is int")
case bool :
fmt.Println("x is bool")
case string:
fmt.Println("x is string")
case []interface{}:
fmt.Println("x is slice")
case map[string]interface{}:
fmt.Println("x is map")
default:
fmt.Println("type unknown")
}
}
PS:據(jù)說json-iteator 是目前golang中對json格式數(shù)據(jù)處理最快的包(比官方j(luò)son包快6倍),好像是滴滴團(tuán)隊(duì)開源的,使用起來也非常方便,有興趣的可以學(xué)習(xí)學(xué)習(xí),下面我們看看官方的示例代碼,使用起來也是很方便
package main
import "github.com/json-iterator/go"
type User struct {
Name string
Age int8
}
func main() {
user := User{
Name: "tanggu",
Age: 18,
}
var jsoniter = jsoniter.ConfigCompatibleWithStandardLibrary
// 序列化
data, err := jsoniter.Marshal(user)
if err != nil {
log.Fatal(err)
}
fmt.Println(string(data))
// 反序列化
var people User
err = jsoniter.Unmarshal(data, people)
if err != nil {
log.Fatal(err)
}
fmt.Println(people)
}
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
您可能感興趣的文章:- golang使用json格式實(shí)現(xiàn)增刪查改的實(shí)現(xiàn)示例
- golang json.Marshal 特殊html字符被轉(zhuǎn)義的解決方法
- golang結(jié)構(gòu)體與json格式串實(shí)例代碼
- Golang JSON的進(jìn)階用法實(shí)例講解
- golang如何自定義json序列化應(yīng)用詳解
- golang json性能分析詳解
- golang中json反序列化可能遇到的問題
- Golang map如何生成有序的json數(shù)據(jù)詳解
- 利用Golang解析json數(shù)據(jù)的方法示例
- Golang中使用JSON的一些小技巧分享
- golang實(shí)現(xiàn)sql結(jié)果集以json格式輸出的方法
- Golang 如何解析和生成json