关于正则表达式的基础语法,这里就不赘述了
go中使用
以字符串text := " <a href="/test/2021-03-17/5436.html" target=########### ">"为例,我们需要提取字符串中href指向的地址
text := " <a href=\"/test/2021-03-17/5436.html\" target=########### \">"
// 生成正则对象,类似Python中的re.compile
// 特别说明,正则中的()是分组的意思
oReg := regexp.MustCompile(` <a href=(?P<href>[\"\w.\-/]+)`)
// 在text中查找,-1位置的参数可以指定个数,-1代表匹配所有,类似于py中可以指定次数的search
res := oReg.FindAllStringSubmatch(text, -1)
//[ <a href="/test/2021-03-17/5436.html" "/test/2021-03-17/5436.html"] []string
fmt.Printf("%v %T\n", res[0], res[0])
//"/test/2021-03-17/5436.html"
fmt.Printf("%v\n", res[0][1])
由此可见,结果为[res1 res2],其中res1是一个字符串分组,其中存放着分组信息,res[0]位置存放匹配的整个字符串,res[1]存放着第一个分组中的信息