2023-05-22 10:43:12 -04:00
---
2023-10-20 03:42:39 -04:00
title: strings.FindRESubmatch
linkTitle: findRESubmatch
2023-05-22 10:43:12 -04:00
description: Returns a slice of all successive matches of the regular expression. Each element is a slice of strings holding the text of the leftmost match of the regular expression and the matches, if any, of its subexpressions.
categories: [functions]
2023-10-20 03:42:39 -04:00
keywords: []
2023-05-22 10:43:12 -04:00
menu:
docs:
parent: functions
2023-10-20 03:42:39 -04:00
function:
aliases: [findRESubmatch]
returnType: '[]string'
signatures: ['strings.FindRESubmatch PATTERN INPUT [LIMIT]']
relatedFunctions:
- strings.FindRE
- strings.FindRESubmatch
- strings.Replace
- strings.ReplaceRE
aliases: [/functions/findresubmatch]
2023-05-22 10:43:12 -04:00
---
2023-08-30 13:23:47 -04:00
By default, `findRESubmatch` finds all matches. You can limit the number of matches with an optional LIMIT argument. A return value of nil indicates no match.
2023-05-22 10:43:12 -04:00
2023-10-20 03:42:39 -04:00
{{% readfile file="/functions/_common/regular-expressions.md" %}}
2023-05-22 10:43:12 -04:00
## Demonstrative examples
```go-html-template
{{ findRESubmatch `a(x*)b` "-ab-" }} → [["ab" ""]]
{{ findRESubmatch `a(x*)b` "-axxb-" }} → [["axxb" "xx"]]
{{ findRESubmatch `a(x*)b` "-ab-axb-" }} → [["ab" ""] ["axb" "x"]]
{{ findRESubmatch `a(x*)b` "-axxb-ab-" }} → [["axxb" "xx"] ["ab" ""]]
{{ findRESubmatch `a(x*)b` "-axxb-ab-" 1 }} → [["axxb" "xx"]]
```
## Practical example
This markdown:
```text
- [Example ](https://example.org )
- [Hugo ](https://gohugo.io )
```
Produces this HTML:
```html
< ul >
< li > < a href = "https://example.org" > Example< / a > < / li >
< li > < a href = "https://gohugo.io" > Hugo< / a > < / li >
< / ul >
```
To match the anchor elements, capturing the link destination and text:
```go-html-template
{{ $regex := `<a\s*href="(.+?)">(.+?)</a>` }}
{{ $matches := findRESubmatch $regex .Content }}
```
Viewed as JSON, the data structure of `$matches` in the code above is:
```json
[
[
"< a href = \"https://example.org \"></ a > Example</ a > ",
"https://example.org",
"Example"
],
[
"< a href = \"https://gohugo.io \"> Hugo</ a > ",
"https://gohugo.io",
"Hugo"
]
]
```
To render the `href` attributes:
```go-html-template
{{ range $matches }}
{{ index . 1 }}
{{ end }}
```
Result:
```text
https://example.org
https://gohugo.io
```
{{% note %}}
You can write and test your regular expression using [regex101.com ](https://regex101.com/ ). Be sure to select the Go flavor before you begin.
{{% /note %}}