关于正则表达式的基础语法,这里就不赘述了
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]存放着第一个分组中的信息
本文介绍了如何在Go语言中使用正则表达式提取HTML标签`<a>`的`href`属性值。通过创建正则表达式并应用到字符串上,找到并返回链接地址。示例代码展示了如何匹配并获取目标字符串中的链接。

被折叠的 条评论
为什么被折叠?



