草庐IT

string-parsing

全部标签

sql - 将 "SELECT *"列读入 []string in go

我想编写一个Go程序,使用SELECT*将数据库表中的行转储到csv文件中。Go提供了优秀的sql和csvapi,但csv需要字符串数组,Rows中的Scan方法会根据类型“填充”字段。由于我之前不认识表格,所以我不知道有多少列以及它们的类型是什么。这是我的第一个Go程序,所以我有点吃力。如何最好地将Rows实例中的列读入[]string-这是“正确”的方式吗?谢谢!更新我还在为这些参数而苦恼。这是我的代码,现在我使用panic而不是返回error,但我稍后会更改它。在我的测试中,我传递了查询结果和os.Stdout。funcdumpTable(rows*sql.Rows,outio.

json - 无法将外部结构直接调用到 map[string]struct

我一直在努力找出在解码JSON时为map[string]struct类型调用外部结构的正确方法。当所有代码都在同一个包中时,代码可以正常工作,但是如果它正在提取导出的类型,那么Unmarshal函数似乎有错误。packageanimalstypeBirdstruct{Namestring`json:"name"`Descriptionstring`json:"description"`}packagemainimport("encoding/json""fmt""../animal")funcmain(){birdJson:=`{"birds":{"name":"eagle","des

arrays - GO 中的 : Parsing byte array of excel data using https://github. com/tealeg/xlsx 库

我想使用https://github.com/tealeg/xlsx解析excel数据的字节数组GOLANG中的库。实际上,我正在从请求(作为字节数组)获取数据到我的GRPC服务器,我必须在其中解析和处理它。我检查了库API,但它接受文件名作为参数。"github.com/tealeg/xlsx"funcmain(){xlsx.OpenFile("file.xslx")}知道如何直接传递字节数组并对其进行处理。 最佳答案 明白了。用过的funcOpenBinary(bs[]byte)(*文件,错误)

mongodb - map[string]interface{} 自切换到新的 go mongo 驱动程序后未被正确解析

我正在切换到新的mongogo驱动程序(mongo-go-driver),远离mgo尽管解码方法没有改变(变成map[string]interface{}),但我们的一个函数不再工作我相信正在发生的事情是返回的数据没有作为map[string]接口(interface)正确处理{}摄取的数据是一个mongo聚合查询:result=map[query_key:procedure_on_citiesquery_type:runprocedurequery_value:map[aggregate:[map[£match:map[Source:Cities]]map[£sort:map[Ord

go - 使用 pg.Array 时如何将 reflect.Pointer() 转换为 []string?

我正在使用go-pg编写自定义查询缓存系统,该系统采用传递给查询函数的查询参数并生成用于Redis的哈希键。我正在使用Go的reflect来检查有效的参数类型,直到我使用pg.Array作为传递的参数。Reflect给了我reflect.Ptr,但是我如何在调用switchcaseblock时提取指针的结构/数组?funcGenerateQueryCacheKey(args...interface{})string{varargumentString=""for_,arg:=rangeargs{v:=reflect.ValueOf(arg)switchv.Kind(){caserefl

string - 根据语言环境将货币/浮点字符串解析为浮点类型

我很困惑如何根据对i18n-locale的了解而不对字符串进行假设,将“float-string”解析为float。示例:当美国人写“1,234.87”时,德国人和我一样写“1.234,87”。在我的项目中,我确实知道我期望的语言环境,但我不想“硬编码”我对本地如何编写这些东西的假设。我不想做正则表达式/字符串替换。有没有一种通用的方式来表达类似的东西myFloat:=ParseFloatByLocale("1.234,76","DE-DE")//myFloat=>1234.76strconv好像没有这个功能,x/text/language也没有感谢任何提示!

go - 如何修复 gomod : `github.com/stretchrcom/testify@v1.4.0: parsing go.mod: unexpected module path "github. com/strethr/testify"`

当我执行gomodtidy时。我收到以下错误:go:github.com/stretchrcom/testify@v1.4.0:parsinggo.mod:unexpectedmodulepath"github.com/stretchr/testify" 最佳答案 此错误是由于在将testify移动到github.com/stretchr/testify之前引用testify的包造成的。解决方案是在您的go.mod中添加以下行:替换github.com/stretchrcom/testifyv1.4.0=>github.com/st

string - 如何将通配符 * 集成到数学验证路由中

我正在构建一个身份验证系统,到目前为止我对它的工作非常满意。但现在我想像下面这样集成一个通配符运算符:如果uri是/user/list并且在允许的映射中有/user/*它必须通过。Allowed{"*":{"administrator","regional"},//logicworks"/user/*":{"administrator"},//howtoimplement"/login":{"administrator","regional"},//logicworks}func(a*Authentication)IsAllowed(req*http.Request,rolestrin

function - 在 Go 模板中,我可以让 Parse 工作但不能让 ParseFiles 以类似的方式工作。为什么?

我有以下代码:t,err:=template.New("template").Funcs(funcMap).Parse("Howdy{{myfunc.}}")在这种形式下一切正常。但是,如果我对ParseFiles做完全相同的事情,将上面的文本放在template.html中,这是不行的:t,err:=template.New("template").Funcs(funcMap).ParseFiles("template.html")我能够让ParseFiles以下列形式工作,但无法让Funcs生效:t,err:=template.ParseFiles("template.html")

json - 如何将 map[string]interface{} 转换为不同类型的结构?

我正在调用一个API,它将像这样返回Json对象:{name:"XXX"type:"TYPE_1"shared_fields:{...}type_1_fields:{...}..type_2_fields:{...}}根据不同的类型,这个对象会有不同种类的字段,但是这些字段对于不同的类型是一定的。因此,我将Json字符串解码为map[string]interface{}以获取不同的类型,但是如何将这些map[string]interface{}转换为某个结构?varfmap[string]interface{}err:=json.Unmarshal(b,&f)type:=f["type