草庐IT

query_commands_here

全部标签

go - 从 exec.Command 输出解析整数

我目前正在尝试从我的Go程序中运行一个命令,并从响应中解析一个整数。该命令返回如下输出:6fyb_src/ex1.fyb(1)wins!使用strings.Split和strings.TrimSpaces拆分行并删除空格效果很好。但是,在尝试将数字解析为整数时出现以下错误:panic:strconv.ParseInt:parsing"0\r1\r2\r3\r4\r5\r6":invalidsyntax但是将我尝试解析的字符串打印到终端会产生以下结果:6我不太确定从这里到哪里去。这个数字对我来说显然像一个整数。错误消息也没有用(至少对我而言)。有人有想法吗?编辑:我正在运行的代码out,

macos - 为什么这个 exec.Command 到另一个打开的 tty 不能正常工作

谁能帮我弄清楚我在这里做错了什么。我正在尝试执行在不同tty中运行的命令(在本例中打开vim),在本例中为/dev/ttys001,它在我终端的另一个选项卡中打开。运行下面的代码确实会在/dev/ttys001的窗口中呈现vim,但是,实际上从那个窗口输入到stdin并没有正确注册。非常感谢任何建议!packagemainimport("log""os""os/exec")funcmain(){tty,err:=os.OpenFile("/dev/ttys001",os.O_RDWR,os.ModePerm)iferr!=nil{log.Fatalln(err)}defertty.Cl

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