DOCUMENTATION: name: regex_replace version_added: "2.0" short_description: replace a string via regex description: - Replace a substring defined by a regular expression with another defined by another regular expression based on the first match. notes: - Maps to Python's C(re.replace). positional: _input, _regex_match, _regex_replace options: _input: description: String to match against. type: str required: true _regex_match: description: Regular expression string that defines the match. type: int required: true _regex_replace: description: Regular expression string that defines the replacement. type: int required: true multiline: description: Search across line endings if C(True), do not if otherwise. type: bool default: no ignorecase: description: Force the search to be case insensitive if C(True), case sensitive otherwise. type: bool default: no EXAMPLES: | # whatami => 'able' whatami: "{{ 'ansible' | regex_replace('^a.*i(.*)$', 'a\\1') }}" # commalocal => 'localhost, 80' commalocal: "{{ 'localhost:80' | regex_replace('^(?P.+):(?P\\d+)$', '\\g, \\g') }}" # piratecomment => '#CAR\n#tar\nfoo\n#bar\n' piratecomment: "{{ 'CAR\ntar\nfoo\nbar\n' | regex_replace('^(.ar)$', '#\\1', multiline=True, ignorecase=True) }}" RETURN: _value: description: String with substitution (or original if no match). type: str