原文链接: 推荐三个实用的 Go 开发工具
孙悟空在花果山称王的时候,特意去了一趟东海,在那里淘到了如意金箍棒。因为身为一个山大王,怎么能没有一件趁手的兵器呢?
作为程序员的我们也一样,除了我们的傍身武器 Ctrl C + V
之外,还要不停的补充我们的武器库。不仅要把 Ctrl C + V
用的高级,更要用的恰到好处。
今天介绍三款小工具,分别可以将 json
,yaml
和 table
转成 Go 的 struct
。下次再碰到这样的转换场景,再也不用皱眉挠头了,一键轻松搞定。
前两个直接在线转换,最后一个需要安装一个库,但也很方便。
json-to-go
地址: https://mholt.github.io/json-to-go/
输入:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| [ { "input_index": 0, "candidate_index": 0, "delivery_line_1": "1 N Rosedale St", "components": { "primary_number": "1", "street_predirection": "N", "street_name": "Rosedale", "street_suffix": "St", "city_name": "Baltimore", "state_abbreviation": "MD" } } ]
|
输出:
1 2 3 4 5 6 7 8 9 10 11 12 13
| type AutoGenerated []struct { InputIndex int `json:"input_index"` CandidateIndex int `json:"candidate_index"` DeliveryLine1 string `json:"delivery_line_1"` Components struct { PrimaryNumber string `json:"primary_number"` StreetPredirection string `json:"street_predirection"` StreetName string `json:"street_name"` StreetSuffix string `json:"street_suffix"` CityName string `json:"city_name"` StateAbbreviation string `json:"state_abbreviation"` } `json:"components"` }
|
yaml-to-go
地址: https://zhwt.github.io/yaml-to-go/
输入:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| image: golang:latest
before_script: - mkdir -p $GOPATH/src/$(dirname $REPO_NAME) - ln -svf $CI_PROJECT_DIR $GOPATH/src/$REPO_NAME - cd $GOPATH/src/$REPO_NAME
stages: - test - build - deploy
format: stage: test script: - go fmt $(go list ./... | grep -v /vendor/) - go vet $(go list ./... | grep -v /vendor/) - go test -race $(go list ./... | grep -v /vendor/)
|
输出:
1 2 3 4 5 6 7 8 9
| type AutoGenerated struct { Image string `yaml:"image"` BeforeScript []string `yaml:"before_script"` Stages []string `yaml:"stages"` Format struct { Stage string `yaml:"stage"` Script []string `yaml:"script"` } `yaml:"format"` }
|
table-to-go
地址 https://github.com/gohouse/converter
假设有这样一张表:
1 2 3 4 5 6 7
| CREATE TABLE `prefix_user` ( `Id` int(11) NOT NULL AUTO_INCREMENT, `Email` varchar(32) NOT NULL DEFAULT '' COMMENT '邮箱', `Password` varchar(32) NOT NULL DEFAULT '' COMMENT '密码', `CreatedAt` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (`Id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户表'
|
使用方式分两种,分别是命令行调用和写 Go 代码:
命令行调用
1、下载对应平台的可执行文件, 下载地址:https://github.com/gohouse/converter/releases
2、命令行执行:
1
| ./table2struct-linux.v0.0.3.bin -file model.go -dsn xxx -table user
|
3、参数说明:
1 2 3 4 5 6 7 8
| -dsn string 数据库dsn配置 -enableJsonTag bool 是否添加json的tag -file string 保存路径 -packageName string 包名 -prefix string 表前缀 -realNameMethod string 结构体对应的表名 -table string 要迁移的表 -tagKey string tag的key
|
Go 代码调用
安装库:
1
| go get github.com/gohouse/converter
|
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
| package main
import ( "fmt" "github.com/gohouse/converter" )
func main() { t2t := converter.NewTable2Struct() t2t.Config(&converter.T2tConfig{ RmTagIfUcFirsted: false, TagToLower: false, UcFirstOnly: false, }) err := t2t. Table("user"). Prefix("prefix_"). EnableJsonTag(true). PackageName("model"). TagKey("orm"). RealNameMethod("TableName"). SavePath("/Users/fizz/go/src/github.com/gohouse/gupiao/model/model.go"). Dsn("root:root@tcp(localhost:3306)/test?charset=utf8"). Run() fmt.Println(err) }
|
输出:
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| package model
import "time"
type User struct { Id int `json:"Id" orm:"Id"` Email string `json:"Email" orm:"Email"` Password string `json:"Password" orm:"Password"` CreatedAt string `json:"CreatedAt" orm:"CreatedAt"` }
func (*User) TableName() string { return "user" }
|
收藏吧!希望你用到的时候还能想起它。