标签:regex AAA 复杂 正则表达式 333 golang 555 com CCC
由于golang标准库regexp不支持per语法,今天收集到一个go语言支持per和c#的工具包;
示例:
package main import ( "fmt" regex "github.com/kshdb/regex_go" ) func main() { //fmt.Println("测试") _str := `[{"AAA":"1111","BBB":"222","CCC":""333 444"","DDD":"555"},{"AAA":"1111","BBB":"222","CCC":""333 444"","DDD":"555"},{"AAA":"1111","BBB":"222","CCC":""333 444"","DDD":"555"},{"AAA":"1111","BBB":""333 444"","CCC":"555","DDD":""}]` reg := regex.MustCompile(`\"\"`, regex.RE2) m, _err := reg.Replace(_str, `"`, 0, -1) fmt.Println("执行的结果是", m, _err) _srt1 := ` hooudcnwtn.com hooeeoooeeeeeen.com www.oo234r44.ss.com hoo666666.com ` reg1 := regex.MustCompile(`(?<=o{2})([2-6a-z\.]+)(?=\.)`, regex.RE2) //sss, _ := reg1.FindStringMatch(_srt1) //获取单个 sss := regexp2FindAllString(reg1, _srt1) //获取批量 fmt.Println("执行的结果是", sss) } /* 获取批量 */ func regexp2FindAllString(re *regex.Regexp, s string) []string { var matches []string m, _ := re.FindStringMatch(s) for m != nil { matches = append(matches, m.String()) m, _ = re.FindNextMatch(m) } return matches }
标签:regex,AAA,复杂,正则表达式,333,golang,555,com,CCC 来源: https://www.cnblogs.com/dfsxh/p/16481697.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。