草庐IT

regex - MustCompile 中的 Golang 正则表达式引用(查找重复字符)

这个问题在这里已经有了答案:Regextomatchrepeatedcharacters(3个答案)关闭6年前。我在使用Go的正则表达式时遇到了困难。它似乎与其他语言不同,有人可以帮助我吗。目标。我希望MustCompile找到字符串中所有重复的字符。APPLE(其中P重复)re:=regexp.MustCompile("(\\w)\\${1}\\+")以上是我试过但根本没用的。基本上我想做的是:([A-Za-z])\1+谁能告诉我我做错了什么?示例如下:https://play.golang.org/p/DeuaIva968

regex - 为什么正则表达式不能正常工作

我对名字进行了验证,当我运行“Start*”时,它不会通过代码,而当我通过“Start$”时,它将通过字符串。下面是程序:-packagemainimport("fmt""regexp")funcmain(){FirstName:="Star*"varvalidName=regexp.MustCompile("^[\\p{L}0-9-_&$.,’'\x60()!/]*$")if!validName.MatchString(FirstName){fmt.Println("--------------",FirstName)}else{fmt.Println(FirstName)}Firs

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顺便说一句,为