Emacs: Regular Expression Syntax
Regular Expression syntax blow are shown without the string delimiters.
In lisp code, backslash may need a backslash in front. Elisp: Regex Backslash in Lisp Code
Character Alternative (Wildcard)
.
- Any single character except newline char.
[chars]
-
Any of the chars.
e.g.
[12x]
means any of 1, 2, or x. [a-z]
-
Any char in the range a to b.
A hyphen inside the square bracket has special meaning. There can be multiple ranges, e.g.
[0-9a-z]
means digits and letters.It also can mix with other chars, e.g.
[♥0-9a-z]
means digits and letters and ♥.The range of characters is considered to be the range of corresponding unicode codepoints. 〔see Unicode: Character Set, Encoding, UTF-8, Codepoint〕 For example,
a
has codepoint 97,z
has codepoint 122,[a-z]
means any char from codepoint 97 to codepoint 122, inclusive.To include a hyphen, put it in the beginning or end, e.g.
[-a-c]
means any a b c and hyphen. [^chars_or_range]
-
not any of the chars_or_range.
e.g.
[^12x]
means any char that is not 1, 2, or x.To include a CIRCUMFLEX ACCENT
^
, add it as second character or at the end. e.g.[^0-9^]
means not any digit nor CIRCUMFLEX ACCENT.;; match html links (progn (re-search-forward "<a href=\\([^>]+\\)>\\([^<]+\\)</a>") (replace-match "(URL: \\1, Link text: \\2)" t) ;; ) ;; <p>See <a href="http://example.com/big.html">xyz</a></p> ;; changed to ;; <p>See (URL: "http://example.com/big.html", Link text: xyz)</p>
Repetition
regex+
-
Match previous pattern 1 or more times. e.g.
a+
means 1 or more occurrence of “a”.[0-9]+
means 1 or more occurrence of digit.(let ((case-fold-search nil)) (re-search-forward "x+")) ;; abc xxx
regex+?
-
Match previous pattern 1 or more times,
but with minimal match (aka non-greedy).
(let ((case-fold-search nil)) (re-search-forward "x+?")) ;; abc xxx
regex*
- Match previous pattern 0 or more times.
regex*?
- Match previous pattern 0 or more times, but with minimal match (aka non-greedy).
regex?
- Match previous pattern 0 or 1 time.
regex??
- Match previous pattern 0 or 1 time, but with minimal match (aka non-greedy).
regex\{m\}
-
Match previous pattern m times.
(let ((case-fold-search nil)) (re-search-forward "x\\{2\\}")) ;; x and xx
regex\{m,n\}
-
Match previous pattern m to n times.
(let ((case-fold-search nil)) (re-search-forward "x\\{2,3\\}")) ;; x xx xxx
Examples of Common Wildcard with Repetition
[0-9]+
-
One or more digits
(let ((case-fold-search nil)) (re-search-forward "[0-9]+")) ;; 100 cats
[A-Za-z]+
- One or more letters of English alphabet.
[-A-Za-z0-9]+
- One or more {letter, digit, hyphen}
[_A-Za-z0-9]+
- One or more {letter, digit, underscore}
[-_A-Za-z0-9]+
- One or more {letter, digit, hyphen, underscore}
Capture
In interactive commands, captured text can be represented as
\1
for first group,
\2
for second group, etc. and
\0
for the entire match, etc.
In emacs lisp code, to get captured group,
use match-string
,
match-beginning
, etc.
See Elisp: Regex Functions
\(regex\)
-
Capture. Captured text can be used later for text replacement, or be referenced in the same regex for a pattern that occur multiple times.
;; capture digit sequence (let ((case-fold-search nil)) (re-search-forward "\\([0-9]+\\)") ;; there are 10 cats (match-string-no-properties 1)) ;; 10
"\(?n:regex\)"
-
Explicit numbered caputure.
Capture and name it by a explicit number n.
(Normally, capture are automatically named in order. First capture is 1, second is 2, etc.) If multiple capture has the same number, the last match win.(let ((case-fold-search nil)) (re-search-forward "\\(?2:[a-z]+\\)") (match-string-no-properties 2)) ;; match
\n
-
reference the nth capture that occured to the left of it.
this lets you match a sub-pattern that are repeated in different places.;; capture a repeated word on both sides of and (let ((case-fold-search nil)) (re-search-forward "\\(\\b[a-z]+\\b\\) and \\1") (match-string-no-properties 0)) ;; this and that and some and else and and and ;; result is ;; "and and and"
Examples of Capture
\([0-9]+\)
-
Capture digit sequence.
(re-search-forward "\\([0-9]+\\)" ) ;; there are 10 cats (match-string-no-properties 1 ) ;; 10
\([A-Za-z]+\)
-
Capture English letter sequence. Do not use
[A-z]
, because that'll match some punctuation chars too. \([-A-Za-z]+\)
- Capture English letter sequence plus hyphen.
\([-_A-Za-z]+\)
- Capture English letter sequence plus hyphen and low line.
\([-_A-Za-z0-9]+\)
- Capture alphanumeric sequence plus hyphen and low line.
"\([^"]+\)"
-
Capture text between quotes, including quotes.
(let ((case-fold-search nil)) (re-search-forward "\"\\([^\"]+\\)\"") (match-string-no-properties 1)) ;; he said "how are you"
Gouping
\(?:regex\)
-
This is called shy group.
Group for precedence, but no capture.
(re-search-forward "\\(?:[0-9]+\\)\\|\\(?:[a-z]+\\)" ) ;; 10 some
Alternative
a\|b
-
Match either pattern.
The alternative operator has very low precedence. that all expressions on either side are considered connected. You can use the capture\(expr\)
or shy group\(?:expr\)
to specify precedence.(let ((case-fold-search nil)) (re-search-forward "jpg\\|jpeg")) ;; cat.jpeg
;; match ax or bx ;; using a alternative with shy group (let ((case-fold-search nil)) (re-search-forward "\\(?:a\\|b\\)x")) ;; ax
Character Classes
Note, these square bracketed character classes must be enclosed in square brackets.
(re-search-forward "[[:ascii:]]+" ) ;; search one or more ascii chars
[:ascii:]
- any ASCII Characters . (codepoint 0 to 127, inclusive)
[:nonascii:]
- any Character that's not ASCII.
[:alnum:]
-
any letter or digit. For multibyte characters, it matches characters whose Unicode
general-category
property (see Character Properties) indicates they are alphabetic or decimal number characters. [:digit:]
-
any
0
to9
. [:xdigit:]
-
for hexadecimal digits.
0
to9
,a
tof
,A
toF
.
[:alpha:]
-
any letter. For multibyte characters, it matches characters whose Unicode
general-category
property indicates they are alphabetic characters. [:graph:]
-
This matches graphic characters. Anything except whitespace, ASCII and non-ASCII control characters, surrogates, and codepoints unassigned by Unicode, as indicated by the Unicode
general-category
property. [:print:]
-
This matches any printing character—either whitespace, or a graphic character matched by
[:graph:]
.
[:blank:]
- any horizontal whitespace, as defined by Unicode. Includes ASCII spaces and tab characters.
[:cntrl:]
- any any character whose code is in the range 0–31. 〔see ASCII Characters〕
[:lower:]
- any lower-case letter, as determined by the current case table. If case-fold-search is true, this also matches any upper-case letter.
[:upper:]
- This matches any upper-case letter, as determined by the current case table. If case-fold-search is non-nil, this also matches any lower-case letter. Case Tables (ELISP Manual)
[:multibyte:]
- This matches any multibyte character. Text Representations (ELISP Manual)
[:unibyte:]
- This matches any unibyte character. Text Representations (ELISP Manual)
Character Classes of Emacs Syntax Table
Some Character Classes in emacs regular expression have a unique feature, that are based on emacs Syntax Table. This effectively means, these character classes may have different meaning depending on which major mode is the current buffer.
〔see Regex Named Character Class and Syntax Table〕
The following character classes are based on Syntax Table.
[:punct:]
- This matches any punctuation character. (At present, for multibyte characters, it matches anything that has non-word syntax in Syntax Table.)
[:space:]
- This matches any character that has whitespace syntax in Syntax Table
[:word:]
- This matches any character that has word syntax in Syntax Table
\w
- This matches any character that has word syntax in Syntax Table
\W
- This matches any character that is not a word syntax in Syntax Table
\scode
-
matches any character whose
Syntax Class
is
code
;; check if next char is a string delimiter (of current syntax table) (looking-at "\\s\"")
\Scode
- matches any character whose Syntax Class is not code
\c
- matches any character whose category is c. Categories (ELISP Manual)
\C
- matches any character whose category is not c. Categories (ELISP Manual)
Boundary Anchors
^regex
- The pattern must match starting from beginning of {line, string, buffer}
regex$
- The pattern must match to end of {line, string, buffer}
\`regex
- The pattern must match starting from Beginning of {string, buffer}
regex\'
- The pattern must match to end of {string, buffer}
\=
-
marker for the current cursor position.
〔see Cursor Position Functions〕 \b
- word boundary marker
\B
- marker for: not a word boundary
\<
-
marker for: beginning of word.
Word characters based on current Syntax Table \>
-
marker for: end of word.
Word characters based on current Syntax Table \_<
-
marker for: beginning of Symbol.
Symbol characters based on current Syntax Table \_>
-
marker for: end of Symbol.
Symbol characters based on current Syntax Table
Matching Unicode Characters
Unicode character can be used literally, e.g.
"♥"
,
or it can be represented by
Elisp: Unicode Escape Sequence
Reference
Emacs, commands using regex
Elisp, Regex in Lisp Code
- Elisp: Regular Expression
- Elisp: Regex Functions
- Emacs: Regular Expression Syntax
- Elisp: Regex Backslash in Lisp Code
- Elisp: Case Sensitivity (case-fold-search)
- Elisp: Find Replace Text in Buffer
- Elisp: Match Data (Regex Result)
- Elisp: Unicode Escape Sequence
- Elisp: Convert Regex to Lisp Regex String
- Elisp: How to Test Regex
- Elisp: Regex in Readable Syntax, Package Rx
- Elisp: Regex Named Character Class and Syntax Table
- Emacs Regex vs Regex in Python, JavaScript, Java