使用一個(gè)例子說明golang如何訪問和修改json文件;主要分三步:
成都創(chuàng)新互聯(lián)公司堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站制作、成都網(wǎng)站建設(shè)、外貿(mào)營銷網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的鹿寨網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
假定用戶輸入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 }
這個(gè)地方主要用的是golang的interface{}數(shù)據(jù)類型,然后把interface{}轉(zhuǎn)換成真正的數(shù)據(jù)類型。
這個(gè)函數(shù)可以擴(kuò)充成動(dòng)態(tài)的解析任何類型,只要把所有的類型全部定義成interface{},然后使用動(dòng)態(tài)類型檢測就可以知道每一個(gè)具體元素的類型了,最終達(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í)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對創(chuàng)新互聯(lián)的支持。