strings.ReplaceRE
Syntax
strings.ReplaceRE PATTERN REPLACEMENT INPUT [LIMIT] ⟼ string
Alias
replaceRE
By default, replaceRE
replaces all matches. You can limit the number of matches with an optional LIMIT argument.
When specifying the regular expression, use a raw string literal (backticks) instead of an interpreted string literal (double quotes) to simplify the syntax. With an interpreted string literal you must escape backslashes.
Go’s regular expression package implements the RE2 syntax. The RE2 syntax is a subset of that accepted by PCRE, roughly speaking, and with various caveats. Note that the RE2 \C
escape sequence is not supported.
This example replaces two or more consecutive hyphens with a single hyphen:
{{ $s := "a-b--c---d" }}
{{ replaceRE `(-{2,})` "-" $s }} → a-b-c-d
To limit the number of replacements to one:
{{ $s := "a-b--c---d" }}
{{ replaceRE `(-{2,})` "-" $s 1 }} → a-b-c---d
You can use $1
, $2
, etc. within the replacement string to insert the groups captured within the regular expression:
{{ $s := "http://gohugo.io/docs" }}
{{ replaceRE "^https?://([^/]+).*" "$1" $s }} → gohugo.io