This is the sixth episode of the “Learning Awk” series that b-yeezi and I are doing.
In the last episode we saw regular expressions in the ‘pattern’ part of a ‘pattern {action}’ sequence. Such a sequence is called a ‘RULE’, (as we have seen in earlier episodes).
$1 ~ /p[elu]/ {print $0}
Meaning: If field 1 contains a ‘p’ followed by one of ‘e’, ‘l’ or ‘u’ print the whole line.
$2 ~ /e{2}/ {print $0}
Meaning: If field 2 contains two instances of letter ‘e’ in sequence, print the whole line.
It is usual to enclose the regular expression in slashes, which make it a regexp constant.
We had a look at many of the operators used in regular expressions in episode 5. Unfortunately, some small errors crept into the list of operators mentioned in that episode. These are incorrect:
The first two operators exist, in languages like Perl and Ruby, but not in GNU Awk.
For the ‘\b’ sequence the GNU manual says:
In other GNU software, the word-boundary operator is ‘\b’. However, that conflicts with the awk language’s definition of ‘\b’ as backspace, so gawk uses a different letter. An alternative method would have been to require two backslashes in the GNU operators, but this was deemed too confusing. The current method of using ‘\y’ for the GNU ‘\b’ appears to be the lesser of two evils.
The corrected list of operators is discussed later in this episode.
Last episode we saw the built-in functions that use regular expressions for manipulating strings. These are sub
, gsub
and gensub
. Regular expressions are used in other functions but we will look at them later.
We will be looking at sub
, gsub
and gensub
in more detail in this episode.
I have written out a set of longer notes for this episode and these are available here.
Unless otherwise stated, our shows are released under a Creative Commons Attribution-ShareAlike 3.0 Unported (CC BY-SA 3.0) license.
The HPR Website Design is released to the Public Domain.