草庐IT

command-query-separation

全部标签

go - 从 golang 的 exec.Command 调用 ghostscrip 时出错

这是我的代码,extraCmds:=[]string{"-q","-dBATCH","-dNOPAUSE","-dSAFER","-sDEVICE=pcxmono",fmt.Sprintf("-r%v",dpi),//-r600“-sOutputFile=BBB%03d.pcx”,“WO-BC-CARE.pdf”,}s,_:=exec.Command("gs",extraCmds...).输出()结果:=字符串log.Println(结果)显示错误,2017/03/2109:24:48错误:/undefinedfilenamein--findlibfile--操作数栈:()执行栈:%i

postgresql - gorm+go+pg : query for related

所以我们有一个有名字的人。名字和姓氏。让我们插入带有名字和姓氏的Person并再次按Name.First查询Person。怎么办?packagemainimport("fmt""log""github.com/jinzhu/gorm")var(pgHoststringpgUserstringpgDatabasestringpgPassstring)typePersonstruct{gorm.ModelName*NameNameIDuint}typeNamestruct{gorm.ModelPersonIDuintFirststringLaststring}funcmain(){//le

戈朗 : command-line-arguments undefined: variable

我想在Golang中创建一个外部函数用于显示使用情况,但我不知道如何调用flag变量。这是我的实际代码:packagemainimport("flag""fmt""os")funcUsage(){ifArgSend{fmt.Printf("Usage:SEND")flag.PrintDefaults()os.Exit(0)}elseifArgTest{fmt.Printf("Usage:-test")flag.PrintDefaults()os.Exit(0)}elseifArgMacro{fmt.Printf("Usage:-macro")os.Exit(0)}else{fmt.Pr

mysql - Golang mysql 客户端 DB.Query 方法不重新编码 utf-8 编码的字符

我有一个mysql表,它的某些列中存储了UTF-8字符。该表是使用DEFAULTCHARSET=utf8创建的;如果我手动运行select语句,我可以看到UTF-8字符,但如果我使用golang客户端并使用DB.Query方法然后我看到字符都是乱码!此外,插入也是从golang客户端完成的。为什么插入内容很好,而读取却出现乱码?在进行查询时,我看不到任何用于设置字符集的参数。我错过了什么? 最佳答案 所以当行被插入数据库时​​,客户端字符集是latin1。默认情况下,golang客户端使用的是utf8。使用utf8再次插入所有行,现

go - 捕获 exec.Command 的缓冲标准输出输出

我正在尝试捕捉外部程序的输出。示例:#include#include#includeintmain(){inti=0;while(i这是我的main.go:packagemainimport("bufio""io""log""os/exec")funcreecho(closerio.ReadCloser){reader:=bufio.NewReader(closer)for{s,e:=reader.ReadString('\n')ife!=nil{log.Println(e)break}log.Println(s)}}funcmain(){cmd:=exec.Command("./in

postgresql - 如果我们将数据库/sql 行对象重新分配给 new Query() 的结果会怎样?它会自动关闭吗?还是我们应该自己关闭它?

我正在使用Golang处理postgresql,我处于必须执行多个查询的情况。如果我将每个查询的结果存储在同一个变量中,我们称之为“行”,每次将该变量重新分配给新的查询结果,它会自动关闭以前的行吗?还是我应该每次都手动关闭它们?如果我应该手动关闭它们,如果我每次都推迟rows.Close()会发生什么?有那么必要吗? 最佳答案 如何调用Rows.Close()*在您再次分配给rows`之前?不,Rows.Close()不会被重新分配自动调用。如果您执行多个不同查询,请使用不同变量来保存每个查询返回的行。分配后为每个调用deferro

macos - 在 golang 中使用 exec.Command,如何打开一个新终端并执行命令?

当我在终端中直接输入命令时,我能够得到以下命令来打开一个新终端并执行命令,但是当我在go中使用exec.Commmand函数时,我无法让它工作。osascript-e'tellapplication"Terminal"todoscript"echohello"'我认为问题出在双引号和单引号中,但我不确定是什么导致了错误。c:=exec.Command("osascript","-e","'tell","application",`"Terminal"`,"to","do","script",`"echo`,`hello"'`)iferr:=c.Run();err!=nil{fmt.Pr

mysql - 如何为 go-sqlmock 正确设置 Mock Row 和 Query

我正在golang中设置测试。我使用go-sqlmock来测试mysql连接。但是sqlmock.NewRows和mock.ExpectQuery不能正常工作并出现错误。我想知道如何解决这个错误。serverside:golangdb:mysqlwebframework:gindao.gofuncGetSingleArticleDao(c*gin.Context,db*sql.DB)(util.Article,*sql.Rows){id:=c.Params.ByName("id")article:=util.Article{}errArticle:=db.QueryRow("SELEC

editor - SciTE 中的多行 command.go

短片这涉及SciTE和Windows(特别是Windows7)中的go语言。这是我第一次使用SciTE,所以如果有其他方法可以实现我的目标,那也很好。目标:一键编译、链接和执行新创建的二进制文件。龙我想在SciTE的“go”命令下设置编译/链接/执行。这可能有点令人困惑,因为它也适用于golanguage。.这是我目前所拥有的:command.compile.*.go=8g$(FileNameExt)command.build.*.go=8l-o$(FileName).exe$(FileName).8command.go.*.go=$(FileName).exe我想要的是:comman

go - 如何将 exec.Command 的输出通过管道传输到 Golang 中的另一个命令

我有八个MicrosoftAccess数据库,每个数据库都有大约215个表,我需要将这些数据库传输到postgresql,所以我使用mdb-tools并导出方案,这只是一步;但是当涉及到直接将表数据导出到postgres时在postgresql中,我必须为每个表编写此命令:mdb-export-Ipostgres-q\'myaccessdatabase.mdbtable-name|psql-dmypsqldatabase-Upostgres-w-hlocalhost所以我一直在尝试编写一个go命令程序来做如下:1.首先执行命令列出表名。这将是下一个命令的参数。2.然后开始forrang