Linux 正则表达式

2019-03-28  本文已影响0人  歌哥居士

通配符

* 代表任意字符
? 代表任意一个字符
[] 代表中括号内任意一个字符

$ touch newFile
$ touch neqFile
$ ls
neqFile newFile
$ ls ne*
neqFile newFile
$ ls ne?File
neqFile newFile
$ ls ne[wq]File
neqFile newFile

正则表达式

* 匹配前一个字符0-任意次。
+ 匹配前一个字符1-任意次。
? 匹配前一个字符0或1次。
. 匹配换行符以外任意一个字符
^ 匹配首。^baozi表示以baozi开头的。
$ 匹配尾。baozi$表示以baozi结尾的。
[] 匹配括号中任意一个字符。
[^] 匹配[]取反。
\ 转义符。
\{n\} 匹配n次。
\{n,\} 匹配不小于n次。
\{n,m\} 匹配最小n次,最多m次。
\d 任意数字
\w 任意字母、数字、_
\s 任意空白字符
# 从左到右匹配,删掉第一个
## 从左到右匹配,删掉全部
% 从右开始,与#相反
%% 从右开始,与##相反

示例:*
第一次可以出现a也可以没有,所以全都显示了。
第二次必须有一个a,所以出现部分符合要求的。

$ grep --color=auto "a*" regFile
a
aa
aaa
aaaa

b
bb
bbb
bbbb


$ grep --color=auto "aa*" regFile
a
aa
aaa
aaaa

示例:+
注意需要加上\ +

$ grep "se\+" regFIle
sesesese
se
seeeeeeese
+se+se+
$ grep "se+" regFIle
+se+se+

示例:.
我在.bashrc文件中加入了alias grep='grep --color=auto',然后source生效

$ grep "s.id" regFile
said
soid
$ grep "s..d" regFile
said
soid
suud
$ grep "s.*d" regFile
said
soid
suud
sooooood

示例:^

$ grep "^s" regFile
said
soid
suud
sooooood

示例:$

$ grep "d$" regFile
said
soid
suud
sooooood

示例:^$(匹配空白行)

$ grep "^$" regFile



$ grep -n "^$" regFile
3:
5:
6:

示例:[]

$ grep "s[ao]id" regFile
said
soid

示例:[^]

$ grep "s[^ao][^i]d" regFile
suud

示例:\

$ grep "aad\.*" regFile
aad..asdasd

示例:{n}

$ grep "a\{2\}" regFile
112aaaaa
aad..asdasd
$ grep "a\{2\}d" regFile
aad..asdasd
$ grep "2a\{2\}" regFile
112aaaaa

示例:{n,}

$ grep "a\{2,\}" regFile
112aaaaa
aad..asdasd
$ grep "2a\{2,\}" regFile
112aaaaa
$ grep "a\{2,\}d" regFile
aad..asdasd

示例:{n,m}

$ grep "a\{2,3\}" regFile
112aaaaa
aad..asdasd

示例:\d

$ grep "\d\{1\}" regFile
1214
124155
112aaaaa

示例:\w

$ grep "\w" regFile
said
soid
suud
sooooood
1214
124155
112aaaaa
aad..asdasd
aa  sets

示例:\s

$ grep "\s\{2\}" regFile
aa  sets

示例:#、##、%、%%

假设我们定义了一个变量为:
file=/dir1/dir2/dir3/my.file.txt
可以用${ }分别替换得到不同的值:
${file#*/}:删掉第一个 / 及其左边的字符串:dir1/dir2/dir3/my.file.txt
${file##*/}:删掉最后一个 /  及其左边的字符串:my.file.txt
${file#*.}:删掉第一个 .  及其左边的字符串:file.txt
${file##*.}:删掉最后一个 .  及其左边的字符串:txt
${file%/*}:删掉最后一个  /  及其右边的字符串:/dir1/dir2/dir3
${file%%/*}:删掉第一个 /  及其右边的字符串:(空值)
${file%.*}:删掉最后一个  .  及其右边的字符串:/dir1/dir2/dir3/my.file
${file%%.*}:删掉第一个  .   及其右边的字符串:/dir1/dir2/dir3/my

记忆的方法为:
# 是 去掉左边(键盘上#在 $ 的左边)
%是去掉右边(键盘上% 在$ 的右边)
单一符号是最小匹配;两个符号是最大匹配
${file:0:5}:提取最左边的 5 个字节:/dir1
${file:5:5}:提取第 5 个字节右边的连续5个字节:/dir2
上一篇下一篇

猜你喜欢

热点阅读