本文实例讲述了Go语言正则表达式用法。分享给大家供大家参考,具体如下:
Go语言的正则表达式使用很简单,示例代码:
package test import ( "fmt" "regexp" ) func RegixBase() { //findTest() //findIndexTest() //findStringTest() //findChinesString() //findNumOrLowerLetter() findAndReplace() } //传入[]byte,返回[]byte func findTest() { str := "ab001234hah120210a880218end" reg := regexp.MustCompile("\\d{6}") //六位连续的数字 fmt.Println("------Find------") //返回str中第一个匹配reg的字符串 data := reg.Find([]byte(str)) fmt.Println(string(data)) fmt.Println("------FindAll------") //返回str中所有匹配reg的字符串 //第二个参数表示最多返回的个数,传-1表示返回所有结果 dataSlice := reg.FindAll([]byte(str), -1) for _, v := range dataSlice { fmt.Println(string(v)) } } //传入[]byte,返回首末位置索引 func findIndexTest() { fmt.Println("------FindIndex------") //返回第一个匹配的字符串的首末位置 reg2 := regexp.MustCompile("start\\d*end") //start开始,end结束,中间全是数字 str2 := "00start123endhahastart120PSend09start10000end" //index[0]表示开始位置,index[1]表示结束位置 index := reg2.FindIndex([]byte(str2)) fmt.Println("start:", index[0], ",end:", index[1], str2[index[0]:index[1]]) fmt.Println("------FindAllIndex------") //返回所有匹配的字符串首末位置 indexSlice := reg2.FindAllIndex([]byte(str2), -1) for _, v := range indexSlice { fmt.Println("start:", v[0], ",end:", v[1], str2[v[0]:v[1]]) } } //传入string,返回string(更加方便) func findStringTest() { fmt.Println("------FindString------") str := "ab001234hah120210a880218end" reg := regexp.MustCompile("\\d{6}") //六位连续的数字 fmt.Println(reg.FindString(str)) fmt.Println(reg.FindAllString(str, -1)) //以下两个方法是类似的 fmt.Println(reg.FindStringIndex(str)) fmt.Println(reg.FindIndex([]byte(str))) } //查找汉字 func findChinesString() { str := "hello中国hello世界和平hi好" reg := regexp.MustCompile("[\\p{Han}]+") fmt.Println(reg.FindAllString(str, -1)) //[中国 世界和平 好] } //查找数字或小写字母 func findNumOrLowerLetter() { str := "HAHA00azBAPabc09FGabHY99" reg := regexp.MustCompile("[\\d|a-z]+") fmt.Println(reg.FindAllString(str, -1)) //[00az abc09 ab 99] } //查找并替换 func findAndReplace() { str := "Welcome for Beijing-Tianjin CRH train." reg := regexp.MustCompile(" ") fmt.Println(reg.ReplaceAllString(str, "@")) //将空格替换为@字符 //Welcome@for@Beijing-Tianjin@CRH@train. }
PS:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用:
JavaScript正则表达式在线测试工具:
http://tools.jb51.net/regex/javascript
正则表达式在线生成工具:
http://tools.jb51.net/regex/create_reg
希望本文所述对大家Go语言程序设计有所帮助。
本文向大家介绍Go语言正则表达式示例,包括了Go语言正则表达式示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Go语言正则表达式。分享给大家供大家参考,具体如下: 返回结果: PS:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用: JavaScript正则表达式在线测试工具: http://tools.jb51.net/regex/javascript 正则表达式在线生成工
在这个问题的背景下,我想做以下修改: 查找: funcA(参数0,参数1,参数2,参数3); 替换: funcA可以有除param0之外的任意数量的参数。怎么做呢?为简单起见,忽略基本情况,即当传递给funcA的参数仅为param0时。 funcA是: 职能是: 编辑: 参数(param1,param2..)只是包含字母的字符串。
本文向大家介绍JAVA中正则表达式匹配,替换,查找,切割的方法,包括了JAVA中正则表达式匹配,替换,查找,切割的方法的使用技巧和注意事项,需要的朋友参考一下 正则表达式的查找;主要是用到String类中的split(); String str; str.split();方法中传入按照什么规则截取,返回一个String数组 常见的截取规则: str.split("\\.")按照.来截取 str.s
主要内容:正则表达式语法规则,Regexp 包的使用正则表达式是一种进行模式匹配和文本操纵的复杂而又强大的工具。虽然正则表达式比纯粹的文本匹配效率低,但是它却更灵活,按照它的语法规则,根据需求构造出的正则表达式能够从原始文本中筛选出几乎任何你想要得到的字符组合。 Go语言通过 regexp 包为正则表达式提供了官方支持,其采用 RE2 语法,除了 、 外,Go语言和 Perl、 Python 等语言的正则基本一致。 正则表达式语法规则 正则表达式是
我想匹配任何文本中的某些行,在匹配中,我想尽可能频繁地替换某个字符。示例文本: 任何文本和“更多”文本。不要在此处替换引号 CatchThis(此处没有引号,“任何更多文本”,“等等…”)。。。 现在,我想用哈希符号来替换圆括号中的每个引号。预期结果: 任何文本和“更多”文本。不要在此处替换引号 CatchThis(此处没有引号,#没有更多文本#,#等等…#)。。。 匹配线条很容易。这是我的模式:
我们得到了一些这样的内容: