Golang将接口文档字段转结构体的实践指南

 更新时间:2025年12月31日 09:15:17   作者:李迟  
这篇文章主要为大家详细介绍了Golang将接口文档字段转结构体的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

本文给出一个从接口文档字段说明文字转换成golang结构体的方法。

问题提出

近期使用golang完成一个数据传输的工程的编写,难度不大,但接口较多,每个接口传输的字段都不少,最多的接口字段,有超过150个。这些字段在查询数据库和发送数据都用到——只是部分字段名称不同,为方便起见,同一接口的数据统一用一个结构体传递——golang支持不同类型的名称。手工一一拷贝比较耗时,于是写了个小代码进行转换。由于接口文档是word格式,可以直接拷贝表格内容到文本文件,再转换。

实现思路和代码

word文档里字段的说明是表格形式的,拷贝出来后变成了tab,为方便起见,需要兼容tab和空格两种形式。golang结构体支持不同类型的名称,具体来说,在结构体中使用db指定查询数据库的名称,使用json指定序列化的字段。

由于接口文档字段使用的类型与golang定义类型不同,如文档里类型为Integer,实际对应golang里的int,这些不同之处,单独列出判断即可。另外要提的是,golang结构体变量第一个字符必须大写,因此要处理这种情况。

如果接口文档的字段是对象类型,或者数据库字段名称和文档名称不同,则要手动修改,但所遇不多。总体上,一个接口的数据统一一种格式,多元一体,大大提高效率。

代码如下:

type MyConvertStruct_t struct {
	Type1 string
	Type2 string
}

var arrType []MyConvertStruct_t = []MyConvertStruct_t{
	{"String", "string"},
	{"Integer", "int"},
	{"Long", "int"},
}

func makeComment(name string) (ret string) {

	ret = fmt.Sprintf("`json:\"%v\" db:\"%v\"`", name, name)

	return
}

func main() {
	filePath := "tmp.txt"
	csvbuf, err := com.ReadTabFile(filePath)
	if err != nil {
		fmt.Println("打开文件失败:", err)
		return
	}

	typeMap := make(map[string]string)
	for _, item := range arrType {
		typeMap[item.Type1] = item.Type2
	}

	fmt.Println("------------------------------")
	for _, row := range csvbuf {
		name := row[0]
		name = strings.TrimSpace(name)
		myType := row[2]
		if value, exists := typeMap[row[2]]; exists {
			myType = value
		}
		comment := makeComment(name)
		// name字段,第一个字符大写
		name = strings.Title(name)
		fmt.Printf("%v %v %v\n", name, myType, comment)
	}
}

测试

输入文件tmp.txt内容如下:

id ID值	String	0
num   	数字	Integer	0
etype	类型	Integer	 0
timestamp	时间	String	0
mCode	号码	String	0
mName	姓名	String	0
age       XX	String	0
addr	地址	String	0
mac	MAC名称	String	0
remark	备注	String	0

注意,上述文件内容使用空格或tab键将不同内容分隔。执行程序后,在终端输出信息如下:

------------------------------
Id string `json:"id" db:"id"`
Num int `json:"num" db:"num"`
Etype int `json:"etype" db:"etype"`
Timestamp string `json:"timestamp" db:"timestamp"`
MCode string `json:"mCode" db:"mCode"`
MName string `json:"mName" db:"mName"`
Age string `json:"age" db:"age"`
Addr string `json:"addr" db:"addr"`
Mac string `json:"mac" db:"mac"`
Remark string `json:"remark" db:"remark"`

小结

从输出结果可以看到,变量名称首字符大写,也生成了jsondb两种格式的字段。符合预期。

到此这篇关于Golang将接口文档字段转结构体的实践指南的文章就介绍到这了,更多相关Golang接口文档字段转结构体内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Golang Gin解析JSON请求数据避免出现EOF错误

    Golang Gin解析JSON请求数据避免出现EOF错误

    这篇文章主要为大家介绍了Golang Gin 优雅地解析JSON请求数据,避免ShouldBindBodyWith出现EOF错误的源码分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-04-04
  • Go一站式配置管理工具Viper的使用教程

    Go一站式配置管理工具Viper的使用教程

    Viper是一个方便Go语言应用程序处理配置信息的库,它可以处理多种格式的配置,这篇文章主要为大家介绍了它的具体使用教程,需要的可以参考下
    2023-08-08
  • go语言编程之select信道处理示例详解

    go语言编程之select信道处理示例详解

    这篇文章主要为大家介绍了go语言编程之select信道处理示例详解,<BR>有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-04-04
  • golang新手们容易犯的3个错误总结

    golang新手们容易犯的3个错误总结

    这篇文章主要给大家介绍了关于golang新手们容易犯的3个错误,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-08-08
  • Go代码检查工具golangci-lint安装使用方法

    Go代码检查工具golangci-lint安装使用方法

    这篇文章主要给大家介绍了关于Go代码检查工具golangci-lint安装使用的相关资料,golangci-lint用于许多开源项目中,比如kubernetes、Prometheus、TiDB等都使用golangci-lint用于代码检查,需要的朋友可以参考下
    2024-01-01
  • Go语言IO输入输出底层原理及文件操作API

    Go语言IO输入输出底层原理及文件操作API

    这篇文章主要为大家介绍了Go语言IO输入输出底层原理及文件操作API示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • Golang实现自己的Redis(pipeline客户端)实例探索

    Golang实现自己的Redis(pipeline客户端)实例探索

    这篇文章主要为大家介绍了Golang实现自己的Redis(pipeline客户端)实例探索,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01
  • Golang中的new()和make()函数本质区别

    Golang中的new()和make()函数本质区别

    在 Go 语言开发中,new() 和 make() 是两个容易让开发者感到困惑的内建函数,尽管它们都用于内存分配,但其设计目的、适用场景和底层实现存在本质差异,本文将通过类型系统、内存模型和编译器实现三个维度,深入解析这两个函数的本质区别,感兴趣的朋友一起看看吧
    2025-02-02
  • Golang三个编译基本命令的使用小结

    Golang三个编译基本命令的使用小结

    本文主要介绍了Golang三个编译基本命令的使用小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • 详解go语言中并发安全和锁问题

    详解go语言中并发安全和锁问题

    这篇文章主要介绍了go语言中并发安全和锁问题,包含互斥锁解锁过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-10-10

最新评论