草庐IT

regex_error

全部标签

go - 在 : panic: runtime error: index out of range 中转换数据结构

我在go中有一个数据结构:typeAPIMainstruct{CodeConvstring`json:"codeConv"`Starttime.Time`json:"start"`Endtime.Time`json:"end"`Details[]struct{IDPrmstring`json:"idPrm"`Keys[]struct{Timestamptime.Time`json:"timestamp"`Valuefloat64`json:"value"`}`json:"keys"`}`json:"details"`}我需要转换为:typeDataGroupedByTSstruct{C

regex - 使用 golang 正则表达式获取 xlsx 单元格数据?

我使用正则表达式从.xlsx文件中获取数据。但我很穷,而且是正则表达式的新手。谁能帮帮我?packagemainimport("fmt""regexp")funcmain(){input:=`{{range.txt}}12321012321`r:=regexp.MustCompile(`]*?r="(\d+)"[^>].*?>.*?[((.*?).*?)]`)r2:=regexp.MustCompile(`(.*?)`)row:=r.FindAllString(input,-1)for_,v:=rangerow{fmt.Println(r.ReplaceAllStringFunc(v,

regex - golang regexp ReplaceAllStrings with backreference不太管用

尝试将单词开头的每个字母大写。我知道有strings.Title,但这对我的需要来说太不精确了。我不确定为什么这不起作用:packagemainimport("fmt""regexp""strings")funcmain(){re:=regexp.MustCompile(`\b([a-z])`)fmt.Println(re.ReplaceAllString("myteststring",strings.ToUpper("$1")))}https://play.golang.org/p/C-8QG1FrOi 最佳答案 你应该使用Rep

regex - Go - 正则表达式操作

我的字符串是:FirstName:ABCD我想捕获以下字符串。ABCD我怎样才能实现它? 最佳答案 我想你需要的是Regexp.FindAllString 关于regex-Go-正则表达式操作,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/38435247/

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

regex - 去正则表达式查找子字符串

我有一个字符串:s:="root112345/root/pathtomyfolder/jdk/jdk.1.8.0.25org.catalina.startup"我需要将版本号grep成一个字符串尝试过,varre=regexp.MustCompile(`jdk.*`)funcmain(){matches:=re.FindStringSubmatch(s)fmt.Printf("%q",matches)} 最佳答案 您需要指定捕获组来提取子匹配项,如packageoverview中所述:If'Submatch'ispresent,th

regex - Go : strings or regexp 中短字符串前缀匹配的更好方法

我知道我得到的字符串会很短(我无法决定是使用strings.Contains,例如strings.Contains("123-ab-foo","123-ab"),还是正则表达式。我显然想要最快的方法。用例示例:ifstrings.Contains(current_string,MY_CONST){//dosmth} 最佳答案 如果您确定要查找的字符串(MY_CONST)将位于current_string的开头,那么最有效的方法将是HasPrefixfuncHasPrefix(s,prefixstring)boolHasPrefixt

regex - 使用 Go 从字符串中删除所有文章和其他字符串?

Go中是否有任何方法或正则表达式可以只删除字符串中使用的冠词?我试过下面的代码可以做到这一点,但它也会从我正在显示下面代码的字符串中删除其他单词:removalString:="Thisisastring"stringToRemove:=[]string{"a","an","the","is"}for_,wordToRemove:=rangestringToRemove{removalString=strings.Replace(removalString,wordToRemove,"",-1)}space:=regexp.MustCompile(`\s+`)trimedExtraSp

regex - 戈兰正则表达式 : FindAllStringSubmatch to []string

我从AmazonS3下载一个多行文件,格式如下:ColumnAv1ColumnBv1ColumnCv1...ColumnAv2ColumnBv2ColumnCv2...文件类型为byte。然后我想用正则表达式解析它:matches:=re.FindAllSubmatch(file,-1)然后我想将结果逐行提供给以[]string作为输入的函数(string[0]是ColumnAv1,string[1]是ColumnBv2,...).我应该如何将[][][]byte的结果转换为包含第一行、第二行等行的[]string?我想我应该循环执行,但我无法正常工作:fori:=0;i顺便说一句,为

go - 如何检查 errors.Errorf() 中的类型错误?

调用fmt.Printf等字符串格式化函数似乎是Go编译器的弱点。我最终遇到了很多错误(重构后使用了错误的格式化程序,忘记包含所有参数),这些错误只会在运行时显示出来。所以我每次写这些的时候都不得不眯着眼睛。我今天做了一些研究,发现了gotoolvet,它似乎适用于fmt.Printf,但它不会捕获errors.Errorf中的错误(见下文)。import"github.com/pkg/errors"funcReturnError(sstring,iint)error{//Swap%dand%s,andforgettoincludethesecondargumentreturnerro