草庐IT

三个字

全部标签

json - 将结构转换为 JSON,其中一个字段是另一个结构

我有两个结构:typeAstruct{Zipstring`json:"zip"`}typeBstruct{Foostring`bson:"foo"`BarA`json:"bar"`}当我尝试json.MarshalB类型时,Bar字段未正确转换。字段没问题,但值始终为空。输出如下所示:{"foo":"some-string-value","bar":{"zip":""}}我做错了什么? 最佳答案 您在A中的Zip字段未填充。typeAstruct{Zipstring`json:"zip"`}typeBstruct{Foostring

arrays - 为什么连接这两个字符串会在 Go 中移动组合字符串的前 3 个字符的末尾 3 个字符?

当尝试连接两个字符串时,它们会合并,但接下来的三个字符会覆盖之前连接的文本,然后再次按预期继续连接。我怀疑这与retrieve_mapped_value(cmd.Interaction.Replies[p_index].Variable[r_index],var_swap)函数有关,因为这种现象仅发生在在build_executable的cmd.Interaction部分的双for中调用。哪里出错了funcbuild_executable(cmdshell_command,var_swapstring_matrix,is_firstbool)string{sleep_duration:

go - 返回字符串的前 n 个字符

返回前n个字符作为字符串的子字符串的最佳方法是什么,当字符串中没有n个字符时,只返回字符串本身。我可以做以下事情:funcfirstN(sstring,nint)string{iflen(s)>n{returns[:n]}returns}但是有没有更简洁的方法呢?顺便说一句,在Scala中,我可以做staken。 最佳答案 除非您想使用unicode,否则您的代码很好:fmt.Println(firstN("世界Hello",1))//�要使其与unicode一起使用,您可以按以下方式修改函数://allocationfreever

regex - 替换字符串中每第 n 个字符实例

我对Go有点陌生,但我正在尝试用逗号替换字符串的每个第n个实例。因此,例如,我的一部分数据如下所示:"2017-06-01T09:15:00+0530",1634.05,1635.95,1632.25,1632.25,769,"2017-06-01T09:16:00+0530",1632.25,1634.9,1631.65,1633.5,506,"2017-06-01T09:17:00+0530",1633.5,1639.95,1633.5,1638.4,991,我想用'\n'替换every6thcomma所以它看起来像"2017-06-01T09:15:00+0530",1634.0

google-chrome - 当我从 chrome websocket 发送 127+ 个字符时,我的 golang 服务器不能看到超过 126 个

我正在重新发明轮子并尝试使用位来实现一个简单的服务器。它几乎可以正常工作,但我不确定这个问题是我的客户端还是我的服务器。这是我从net.ConnRead传递结果字节数组的函数funcreadWsFrame(p[]byte){//processfirstbyteb:=p[0]fmt.Printf("firstbyte:%b\n",b)fin:=b&128//hopefully128,forfinop:=b&15//hopefully1,fortextfmt.Printf("fin:%d\nop:%d\n",fin,op)//processsecondbyteb=p[1]fmt.Print

javascript - 创建一个双头动态表,其中填充了从 golang 服务器提取的三个不同数组的元素

我需要生成一个双头表,从三个不同的数组中提取数据-乘客、通行证和价格。Riders(列标题)和Passes(行标题)都是标题。价格是乘客和通行证相交的地方。所以像这样:https://www.w3.org/WAI/tutorials/tables/two-headers/这是我成功的地方:根据数组的长度生成具有正确行数/列数的表格单元格正在使用每个数组中的元素自动填充。这是我挣扎的地方:标题(通过)仅针对顶行中的每个单元格一遍又一遍地显示数组中的第一个元素。第二行在每个单元格中一遍又一遍地仅显示rider数组的第一个元素。其余单元格填充了价格,但它们跨越了整行。因此,看到的不是$1.0

go-pg "belongs to"2个字段到同一个表

我正在使用https://github.com/go-pg/pg处理这些东西,在建立一个基本的属于关系方面有很大的问题。所以基本上我有一个包含列receipient_id和sender_id的表,它们都指向同一个用户表。这是我的代码和结果:typeTransactionstruct{IdintReceipient*User`json:"receipient_id"sql:"-"validate:"required"`Sender*User`json:"sender_id"sql:"-"validate:"required"`TransactionTypeint`json:"transa

golang 从 net.TCPConn 中以 4 个字节作为消息分隔读取字节

我正在golang中开发SIPoverTCP模拟服务。传入的SIP消息由'\r\n\r\n'序列分隔(我现在不关心SDP)。我想根据该分隔符提取消息并将其发送到处理goroutine。通过golang标准库,我看不到实现它的简单方法。io和bufio包似乎没有一站式服务。目前我看到两个前进的选择(bufio):*Reader.ReadBytes函数,'/r'设置为分隔符。进一步的处理是通过使用ReadByte函数并将其与定界符的每个字节按顺序进行比较并在必要时取消读取它们来完成的(这看起来很乏味)将Scanner与自定义拆分功能结合使用,这看起来也不是太琐碎。我想知道是否还有其他更好的

go - 如何在 socks5 代理中将 2 个字节的端口号返回给客户端?

我正在尝试实现socks5代理服务器。根据rfc,大多数事情都很清楚,但我仍然无法解释客户端端口并以字节为单位写入我的端口号。我创建了一个函数,它tkes一个int并返回2个字节。此函数首先将数字转换为二进制,然后按字面意思将位拆分为字符串,然后将它们转换回字节。但这似乎是错误的,因为如果最右边的位为0,它们就会丢失。这是函数funcgetBytesOfInt(iint)[]byte{binary:=fmt.Sprintf("%b",i)ifi你能解释一下我应该如何解析数字并获得2个字节,最重要的是我如何将它转换回整数。目前,如果您将1024赋给此函数,它将返回[]byte{0x80,

go - ioutil.ReadAll 为 tar 阅读器提供 0 个字节

我在内存中创建一个tar文件:varbufbytes.Buffertw:=tar.NewWriter(&buf)files:=map[string][]byte{"1.txt":[]byte("11"),"2.txt":[]byte("2"),}forfileName,bStr:=rangefiles{b:=[]byte(bStr)hdr:=&tar.Header{Name:fileName,Mode:0600,Size:int64(len(b)),}log.Printf("includethefiletothetar%+v\n",hdr)iferr:=tw.WriteHeader(h