golang中json和struct的使用說明
1、返回json響應結果
在struct的字段後面加入json:”key”可以進行json格式輸出,其中key為json的鍵名
type SuccessResponse struct { Code int `json:"code"` Msg string `json:"msg"` Data interface{} `json:"data"` } func SuccessRsp(ctx *gin.Context, data interface{}) { res := SuccessResponse{ Code: 0, Msg: "success", Data: data, } ctx.JSON(http.StatusOK, res) } type MyData struct { Id int `json:"id"` Name string `json:"name"` } func ListAllOncallPlan(ctx *gin.Context) { //你的業務代碼 //...... data = Mydata{Id:1, Name:"zhangsan"} SuccessRsp(ctx, plans) } 響應的結果為: { "code": 0, "msg": "ok", "data": { "id": 1, "name": "zhangsan" } }
tips:
1.如果struct的某個字段沒有傳值,則輸出的json為默認值,可以通過”omitempty”參數忽略掉值為空的鍵
type MyData struct { Id int `json:"id,omitempty"` Name string `json:"name"` } data = Mydata{Name:"zhangsan"} SuccessRsp(ctx, plans)
則id的鍵會被忽略掉,輸出json為:
{ "code": 0, "msg": "ok", "data": { "name": "zhangsan" } }
2.可以用”-“來完全掉忽略掉某個鍵, 比如下面的id不會被轉化到json字段中
type MyData struct { Id int `json:"-"` Name string `json:"name"` }
2、將數據庫的字段轉化成struct
如果使用gorm框架進行數據庫連接,則可以用gorm:”column:key”來指定數據庫的鍵,如下所示
type User struct { Id int64 `gorm:"column:id" json:"id"` Name string `gorm:"column:name" json:"name,omitempty"` }
補充:golang 一鍵生成 form,json,gorm標簽
每次有新表產生時,就會有新的model,model編寫完後,繁雜的標簽註解令人煩躁,所以寫瞭這樣的工具。
func AddJsonFormGormTag(in string) (string) { var result string scanner := bufio.NewScanner(strings.NewReader(in)) var oldLineTmp = "" var lineTmp = "" var propertyTmp = "" var seperateArr []string for scanner.Scan() { oldLineTmp = scanner.Text() lineTmp = strings.Trim(scanner.Text(), " ") if strings.Contains(lineTmp, "{") || strings.Contains(lineTmp, "}") { result = result + oldLineTmp + "\n" continue } seperateArr = Split(lineTmp, " ") // 接口或者父類聲明不參與tag, 自帶tag不參與tag if len(seperateArr) == 1 || len(seperateArr) == 3 { continue } propertyTmp = HumpToUnderLine(seperateArr[0]) oldLineTmp = oldLineTmp + fmt.Sprintf(" `gorm:\"column:%s\" json:\"%s\" form:\"%s\"`", propertyTmp, propertyTmp, propertyTmp) result = result + oldLineTmp + "\n" } return result } // 增強型split,對 a,,,,,,,b,,c 以","進行切割成[a,b,c] func Split(s string, sub string) []string { var rs = make([]string, 0, 20) tmp := "" Split2(s, sub, &tmp, &rs) return rs } // 附屬於Split,可獨立使用 func Split2(s string, sub string, tmp *string, rs *[]string) { s = strings.Trim(s, sub) if !strings.Contains(s, sub) { *tmp = s *rs = append(*rs, *tmp) return } for i, _ := range s { if string(s[i]) == sub { *tmp = s[:i] *rs = append(*rs, *tmp) s = s[i+1:] Split2(s, sub, tmp, rs) return } } } // 駝峰轉下劃線 func HumpToUnderLine(s string) string{ if s =="ID" { return "id" } var rs string elements:=FindUpperElement(s) for _,e :=range elements{ s =strings.Replace(s, e, "_"+strings.ToLower(e),-1) } rs = strings.Trim(s," ") rs = strings.Trim(rs,"\t") return strings.Trim(rs,"_") } // 找到字符串中大寫字母的列表,附屬於HumpToUnderLine func FindUpperElement(s string) []string { var rs = make([]string, 0, 10) for i := range s { if s[i] >= 65 && s[i] <= 90 { rs = append(rs, string(s[i])) } } return rs }
如何使用
func TestAddJsonFormTag(t *testing.T) { rs := AddJsonFormGormTag(` type User struct{ Id uint64 NameSpace string DailyRoutine int } `) fmt.Println(rs) }
結果
type User struct{ Id uint64 `gorm:"column:id" json:"id" form:"id"` NameSpace string `gorm:"column:name_space" json:"name_space" form:"name_space"` DailyRoutine int `gorm:"column:daily_routine" json:"daily_routine" form:"daily_routine"` }
具體對齊,使用go fmt xxx.go 命令
goland 快捷鍵是 ctrl alt L
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。
推薦閱讀:
- GO項目實戰之Gorm格式化時間字段實現
- 解決Golang json序列化字符串時多瞭\的情況
- Golang 使用gorm添加數據庫排他鎖,for update
- gorm+gin實現restful分頁接口的實踐
- Golang的strings.Split()踩坑記錄