This is an old revision of the document!
$ man re_format
Означает любое количество символа в строке, предшествующего “звездочке”, в том числе и нулевое число символов.
Означает не менее одного любого символа
Означает начало строки, но иногда, в зависимости от контекста, означает отрицание в регулярных выражениях.
$ grep '^s' /etc/passwd sshd:*:22:22:Secure Shell Daemon:/var/empty:/usr/sbin/nologin smmsp:*:25:25:Sendmail Submission User:/var/spool/clientmqueue:/usr/sbin/nologin
В конце регулярного выражения соответствует концу строки.
$ grep 'sh$' /etc/passwd
Предназначены для задания подмножества символов. Квадратные скобки, внутри регулярного выражения, считаются одним символом, который может принимать значения, перечисленные внутри этих скобок. Метасимвол ^ означает отрицание множества
$ grep '^[rs]' /etc/passwd
Служит для экранирования специальных символов, это означает, что экранированные символы должны интерпретироваться буквально, т.е. как простые символы (в некоторых случаях наоборот).
Отмечают границы слова (не работает в sed).
$ grep 'var' /etc/login.conf :setenv=MAIL=/var/mail/$,BLOCKSIZE=K,FTP_PASSIVE_MODE=YES:\ :nologin=/var/run/nologin:\ # Russian Users Accounts. Setup proper environment variables. # :setenv=MAIL=/var/mail/$,BLOCKSIZE=K:\ # :nologin=/var/run/nologin:\ $ grep '\<var\>' /etc/login.conf :setenv=MAIL=/var/mail/$,BLOCKSIZE=K,FTP_PASSIVE_MODE=YES:\ :nologin=/var/run/nologin:\ # :setenv=MAIL=/var/mail/$,BLOCKSIZE=K:\ # :nologin=/var/run/nologin:\
Предназначены для выделения групп регулярных выражений. Они полезны при использовании с оператором “\|” и при извлечении подстроки.
$ grep 'daily\|weekly' /etc/crontab # Perform daily/weekly/monthly maintenance. 1 3 * * * root periodic daily 15 4 * * 6 root periodic weekly $ grep 'periodic \(daily\|weekly\)' /etc/crontab 1 3 * * * root periodic daily 15 4 * * 6 root periodic weekly $ ls /usr/bin | sed 's/\(.*\)/rm \1/' rm CC rm Mail rm addftinfo ... $ ls /usr/bin | sed -n 's/\(^a.*\)/rm \1/p' rm addftinfo rm addr2line rm afmtodit ... $ cat > catalog.txt petrof ivan 234-56-78 ivanof sidor 214-56-78 <Ctrl-D> $ sed 's/\(.*\) .* \(.*\)/\1 \2/' catalog.txt petrof 234-56-78 ivanof 214-56-78
Задают число вхождений предыдущего выражения.
$ grep '\(ro.*\)\{2\}' /etc/passwd root:*:0:0:Charlie &:/root:/bin/csh daemon:*:1:1:Owner of many system processes:/root:/usr/sbin/nologin
[:class:] это альтернативный способ указания диапазона символов.
$ grep '\<[[:alpha:]]\{X\}\>' /etc/login.conf :ignorenologin:\ # :ignorenologin:\ # :maxmemorysize-cur=128M:\ # :refreshperiod@:\ # :refreshperiod@:\ $ grep '\<[A-Za-z]\{X\}\>' /etc/login.conf
Заменяем в файле catalog.txt пробел на TAB
$ sed 's/\(.*\)[[:space:]].*[[:space:]]\(.*\)/\1 \2/' catalog.txt petrof 234-56-78 ivanof 214-56-78
Многие символы экранируемые в базовых выражениях – () {} | – но не – <> – используются без экранирования.
Означает, что предыдущий символ или регулярное выражение встречается 0 или 1 раз.
$ grep -E '^r?o' /etc/passwd root:*:0:0:Charlie &:/root:/bin/csh operator:*:2:5:System &:/:/usr/sbin/nologin
Указывает на то, что предыдущий символ или выражение встречается 1 или более раз (добавляем произвольное количество символов разделителей в файл catalog.txt).
$ sed -E 's/([[:alpha:]]+)[[:space:]]+.*[[:space:]]+([[:alpha:]]*)/\1 \2/' catalog.txt petrof 234-56-78 ivanof 214-56-78