跳至内容

正则表达式和通配符

在 GNU/Linux 操作系统中,正则表达式和通配符通常具有相同的符号(或样式),因此人们经常混淆它们。

正则表达式和通配符有什么区别?

相似之处

  • 它们具有相同的符号,但表示完全不同的含义。

不同之处

  • 正则表达式匹配文件内容;通配符通常用于匹配文件或目录名。
  • 正则表达式通常用于 grepsedawk 等命令。
  • 通配符通常与 cpfindmvtouchls 等命令一起使用。

GNU/Linux 中的通配符

GNU/Linux 操作系统支持以下通配符

通配符样式作用
?匹配文件或目录名中的一个字符。
*匹配文件或目录名中的 0 个或多个任意字符。
[ ]匹配括号中任何单个字符。例如,[one] 表示匹配 o 或 n 或 e。
[-]匹配括号中给定范围内的任何单个字符。例如,[0-9] 匹配 0 到 9 之间的任何单个数字。
[^]"逻辑非" 匹配单个字符。例如,[^a-zA-Z] 表示匹配单个非字母字符。
{,}多个单个字符的非连续匹配。用逗号隔开。
{..}与 [-] 相同。例如 {0..9} 和 {a..z}

不同的命令对通配符样式的支持不同

  • find: 支持 *、?、[ ]、[-]、[^]
  • ls: 全部支持
  • mkdir: 支持 {,} 和 {..}
  • touch: 支持 {,} 和 {..}
  • mv: 全部支持
  • cp: 全部支持

例如

Shell > mkdir -p /root/dir{1..3}
Shell > cd /root/dir1/
Shell > touch file{1,5,9}
Shell > cd 
Shell > mv /root/dir1/file[1-9]  /root/dir2/
Shell > cp /root/dir2/file{1..9} /root/dir3/
Shell > find / -iname "dir[1-9]" -a -type d

GNU/Linux 中的正则表达式

由于历史发展,存在着两种主要的正则表达式学派

  • POSIX
    • BRE(基本正则表达式)
    • ERE(扩展正则表达式)
    • POSIX 字符类
  • PCRE(与 Perl 兼容的正则表达式):各种编程语言中最常见的。
BREEREPOSIX 字符类PCRE
grep
(需要 -E 选项)

(需要 -P 选项)
sed
(需要 -r 选项)
×
awk×

有关正则表达式的更多信息,请访问 此网站 以获取更多有用的信息。

BRE

BRE(基本正则表达式)是最古老的正则表达式类型,由 UNIX 系统中的 grep 命令和 ed 文本编辑器引入。

元字符描述bash 示例
*匹配前一个字符出现的次数,可以是 0 次或任意多次。
.匹配除换行符以外的任何单个字符。
^匹配行开头。例如 - ^h 将匹配以 h 开头的行。
$匹配行尾。例如 - h$ 将匹配以 h 结尾的行。
[]匹配括号中指定的任何单个字符。例如 - [who] 将匹配 w 或 h 或 o;[0-9] 将匹配一位数字;[0-9][a-z] 将匹配由一位数字和一个单个小写字母组成的字符。
[^]匹配除括号中字符以外的任何单个字符。例如 - [^0-9] 将匹配任何单个非数字字符。[^a-z] 将匹配任何单个不是小写字母的字符。
\转义字符,用于取消某些特殊符号所表示的含义。echo -e "1.2\n122" \| grep -E '1\.2'
1.2
\{n\}匹配前一个单个字符出现的次数,n 代表匹配的次数。echo -e "1994\n2000\n2222" \| grep "[24]\{4\}"
2222
\{n,\}至少匹配前一个单个字符 n 次。echo -e "1994\n2000\n2222" \| grep "[29]\{2,\}"
1994
2222
\{n,m\}至少匹配前一个单个字符 n 次,最多匹配 m 次。echo -e "abcd\n20\n300\n4444" \| grep "[0-9]\{2,4\}"
20
300
4444

ERE

元字符描述bash 示例
+匹配前一个单个字符出现的次数,可以是 1 次或多次。echo -e "abcd\nab\nabb\ncdd" \| grep -E "ab+"
abcd
ab
abb
?匹配前一个单个字符出现的次数,可以是 0 次或 1 次。echo -e "ac\nabc\nadd" \| grep -E 'a?c'
ac
abc
\<边界字符,匹配字符串的开头。echo -e "1\n12\n123\n1234" \| grep -E "\<123"
123
1234
\>边界字符,匹配字符串的结尾。echo -e "export\nimport\nout" \| grep -E "port\>"
export
import
()组合匹配,即括号中的字符串作为一个组合,然后匹配。echo -e "123abc\nabc123\na1b2c3" \| grep -E "([a-z][0-9])+"
abc123
a1b2c3
|管道符号代表“或”的意思。echo -e "port\nimport\nexport\none123" \| grep -E "port\>\|123"
port
import
export
one123

ERE 也支持具有特殊含义的字符

特殊字符描述
\w等效于 [a-zA-Z0-9]
\W等效于 [^a-zA-Z0-9]
\d等效于 [0-9]
\D等效于 [^0-9]
\b等效于 \<\>
\B匹配非边界字符。
\s匹配任何空白字符。等效于 [ \f\n\r\t\v]
\S等效于 [^ \f\n\r\t\v]
空白字符描述
\f匹配单个换页符。等效于 \x0c\cL
\n匹配单个换行符。等效于 \x0a\cJ
\r匹配单个回车符。等效于 \x0d\cM
\t匹配单个制表符。等效于 \x09\cI
\v匹配单个垂直制表符。等效于 \x0b\cK

POSIX 字符

有时,您可能会看到 "POSIX 字符"(也称为 "POSIX 字符类")。请注意,作者很少使用 "POSIX 字符类",但已包含此部分以增强基本理解。

POSIX 字符等效于
[:alnum:][a-zA-Z0-9]
[:alpha:][a-zA-Z]
[:lower:][a-z]
[:upper:][A-Z]
[:digit:][0-9]
[:space:][ \f\n\r\t\v]
[:graph:][^ \f\n\r\t\v]
[:blank:][ \t]
[:cntrl:][\x00-\x1F\x7F]
[:print:][\x20-\x7E]
[:punct:][][!"#$%&'()*+,./:;<=>?@^_`{|}~-]
[:xdigit:][A-Fa-f0-9]

介绍正则表达式

许多网站存在用于在线练习正则表达式技能,例如

作者:tianci li