golang 中判断结构体中某一个属性是否存在(以区分零值)

原问题地址:validate-struct field if it exists

有定义结构

go 复制代码
package main

import (
	"fmt"
	"encoding/json"
)

type User struct {
    Name     string  `json:"name,omitempty"`
    Username *string `json:"username,omitempty"`
    Email    string  `json:"email,omitempty"`
    Town     string  `json:"town,omitempty"`
    //more fields here
}

func main() {
    var u, u2 User
    json.Unmarshal([]byte(`{"username":"hi"}`), &u)
    fmt.Println("username set:", u.Username != nil, *u.Username)
    json.Unmarshal([]byte(`{}`), &u2)
    fmt.Println("username set:", u2.Username != nil)
    fmt.Println("Hello, playground")
}

反射方式

go 复制代码
import (
	"log"
	"reflect"
)

func main() {
	type test struct {
		A bool
		B bool
		C bool
	}

	v := new(test)
	metaValue := reflect.ValueOf(v).Elem()

	for _, name := range []string{"A", "C", "Z"} {
		field := metaValue.FieldByName(name)
		if field == (reflect.Value{}) {
			log.Printf("Field %s not exist in struct", name)
		}
	}
}

借助 json 库

go 复制代码
package main

import (
	"fmt"
	"encoding/json"
)

func main() {
    fmt.Println("Hello, World!")
	type Meta struct{
		FcTag struct{
			Name string `json:"name"`
			Value json.Number `json:"value"`
		} `json:"fc_tag"`
	}
	template := `{"fc_tag": {"name": "tiger"}}`
	var meta1 Meta
	err := json.Unmarshal([]byte(template), &meta1)
	if err != nil {
		fmt.Println("err=", err.Error())
	}else{
		fmt.Printf("meta1=%#v\n", meta1.FcTag.Value)
	}
	
	template = `{"fc_tag": {"name": "tiger", "value": 1}}`
	var meta2 Meta
	err2 := json.Unmarshal([]byte(template), &meta2)
	if err2 != nil {
		fmt.Println("err=", err2.Error())
	}else{
		fmt.Printf("meta2=%#v\n", meta2.FcTag.Value)
	}
}

/*
  Hello, World!
  meta1=""
  meta2="1"
*/

给以后解决类似问题,提供了不错的思路👍🏻

相关推荐
老猿讲编程16 分钟前
一个例子来说明Ada语言的实时性支持
开发语言·ada
Chrikk1 小时前
Go-性能调优实战案例
开发语言·后端·golang
幼儿园老大*1 小时前
Go的环境搭建以及GoLand安装教程
开发语言·经验分享·后端·golang·go
canyuemanyue1 小时前
go语言连续监控事件并回调处理
开发语言·后端·golang
杜杜的man1 小时前
【go从零单排】go语言中的指针
开发语言·后端·golang
Ai 编码助手2 小时前
MySQL中distinct与group by之间的性能进行比较
数据库·mysql
陈燚_重生之又为程序员3 小时前
基于梧桐数据库的实时数据分析解决方案
数据库·数据挖掘·数据分析
caridle3 小时前
教程:使用 InterBase Express 访问数据库(五):TIBTransaction
java·数据库·express
白云如幻3 小时前
MySQL排序查询
数据库·mysql
萧鼎3 小时前
Python并发编程库:Asyncio的异步编程实战
开发语言·数据库·python·异步