草庐IT

protobuf序列化

全部标签

templates - 带有 mustache 的未排序列表的结构 slice

我有一个结构。typeDataKeystruct{Idint64`db:"id"`UserIdstring`db:"user_id"`Datastring`db:"data"`CreatedAttime.Time`db:"created_at"`}我创建了一片结构。data:=[]DataKey{}在执行sql查询并填充slice后,我尝试传递给mustache建立我的list。mustache.RenderFileInLayout("templates/datakeys.html.mustache","templates/layout.html.mustache",user,data

go - 无法检测到 go protobuf 的版本控制系统

在我的go项目上运行goget我收到以下错误消息:packagecode.google.com/p/goprotobuf/proto:无法检测code.google.com/路径的版本控制系统我什么都没有改变,这是怎么回事? 最佳答案 golangprotobuf项目已从googlecode移动至github.用于从ProtocolBuffer定义生成go代码的protoc版本已过时并使用旧导入。从github项目说明安装protoc-gen-go:https://github.com/golang/protobuf

json - 在 Golang 中反序列化模式字段

我正在编写golang结构,它与一些json结构兼容。然而,大多数字段都是已知的,在json定义中会有一些字段遵循某些特定模式(如“x-{randomName}”),我也想将其反序列化为某个字段作为map[string]interface{}也是如此。有什么下降的方法可以实现吗? 最佳答案 效率较低,但您可以解码两次以避免手动映射字段。一次将所有正确标记的字段放入结构中,然后再次放入map[string]interface{}以获取其他所有内容。如果您不关心重复字段,您甚至不需要过滤第二张map。您甚至可以在UnmarshalJSO

go - viper yaml 配置序列

我正在尝试使用viper(seeviperdocs)读取yaml配置文件。但是我看不到一种方法来读取问题类型下的map值序列。我尝试了各种Get_方法但似乎没有人支持这一点。remote:host:http://localhost/user:adminpassword:changeitmapping:source-project-key:ITremote-project-key:SCRUMissue-types:-source-type:Incidentremote-type:Task-source-type:ServiceRequestremote-type:Task-source-

json - 如何将 hit.Source 反序列化为 golang 中的结构

我一直在使用这个存储库:https://github.com/olivere/elastic下一段代码是golang中elasticsearch查询的例子:searchResult,err:=client.Search().Index("mx").Type("postal_code").Source(searchJson).Pretty(true).Do()iferr!=nil{panic(err)}ifsearchResult.Hits.TotalHits>0{for_,hit:=rangesearchResult.Hits.Hits{vardDocumenterr:=json.Un

mongodb - 从请求中序列化一个表单并放入 mongo

我试图将来自请求的表单(我暂时不知道我得到的数据的结构)放入mongo数据库中。这是我的代码:fmt.Println(r.Form)forkey,values:=ranger.Form{//rangeovermapfor_,value:=rangevalues{//rangeover[]stringfmt.Println(key,value)}}fmt.Println(r.Form)decoder:=json.NewDecoder(r.Body)session,err:=mgo.Dial("127.0.0.1")iferr!=nil{panic(err)}defersession.Cl

go - YAML MapSlice 在编码或解码时保留序列

我对如何使用YAMLMapSlice数据结构感到困惑。来自这里https://sourcegraph.com/go/gopkg.in/yaml.v2/-/MapSlice.我设法解码为一种MapSlice但如何将其映射到我自己的结构vardata=`id:id-jakut:en:name:NorthJakartaCitylabel:NorthJakartaid:name:KotaJakartaUtaralabel:JakartaUtaraid-jaksel:en:name:SouthJakartaCitylabel:SouthJakartaid:name:KotaJakartaSela

go - Bazel 构建、protobuf 和代码完成

使用Bazel时要构建包含.proto文件的项目,我们可以使用例如go_binary和go_proto_library规则来创建二进制文件。生成的二进制文件将按预期工作,但从.proto文件生成的代码不在工作目录中。因此,编辑器和IDE中的代码补全将不起作用。更糟糕的是,它们经常会打印有关无效导入语句的错误。这是一个使用ProtocolBuffer的示例,但可能还有其他类似的情况,例如使用第三方依赖项。这通常是如何处理的? 最佳答案 我是为Bazel制定Go规则的工程师之一。不幸的是,我现在没有一个好的答案给你,但这个问题在我们的雷

go - 这个 if 序列可以写得更优雅吗?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭5年前。Improvethisquestionifv,ok:=os.LookupEnv("IDAASHTTPPORT");ok{c.HTTPPort,_=strconv.Atoi(v)}ifv,ok:=os.LookupEnv("IDAASDBNAME");ok{c.DBUserName=v}ifv,ok:=os.LookupEnv("IDAASDBPW");ok{c.DBPasswd=v}ifv,ok:=os.LookupEnv("

go - 序列化结构字段以预先存在 byte slice

我有一个设置,可以通过网络接收数据并将其序列化到我的结构中。它工作正常,但现在我需要将数据序列化到slice缓冲区以通过网络发送它。我试图避免分配超过需要的空间,所以我已经设置了一个缓冲区,我想为我的所有序列化写入该缓冲区。但我不确定该怎么做。我的设置是这样的:recieveBuffer:=make([]byte,1500)header:=recieveBuffer[0:1]message:=recieveBuffer[1:]因此,我尝试将结构中的字段写入message,并将所有字段的总字节数作为header的值。这就是我反序列化结构的方式://Deserialize...func(u