-e
基本正则,-E
扩展版正则
-E
,-r
,--regexp-extended
在脚本中使用扩展正则表达式(为保证可移植性使用 POSIX -E)。-e
或--expression
接基本正则表达式, 可多次使用,多次过滤-f
或--file
选项接脚本文件, 注意 是脚本文件, 而不是输入文件
-e可以不写, 如果没有 -e, --expression, -f 或 --file 选项,那么第一个非选项参数被视为
sed脚本。
其他非选项参数被视为输入文件,如果没有输入文件,那么程序将从标准
输入读取数据。
和grep一样找出文本文件中的匹配行
默认都是普通版正则
bash
# p要与-n连用, 不知为社么
sed -n /pattern/p x.txt
# ↑功能等效↓
sed -ne /pattern/p x.txt
# ↑功能等效↓
grep pattern x.txt
# ↑功能等效↓
cat x.txt | sed -n /pattern/p
# ↑功能等效↓
cat x.txt | sed -ne /pattern/p
# ↑功能等效↓
cat x.txt | grep pattern
扩展版正则
bash
# p要与-n连用, 不知为社么
sed -nE /pattern/p x.txt
# ↑功能等效↓
grep -E pattern x.txt
# ↑功能等效↓
cat x.txt | sed -nE /pattern/p
# ↑功能等效↓
cat x.txt | grep -E pattern
sed查找替换
bash
# 源文件不会被替换, 只输出的内容被替换
# g是整个文档, i是忽略大小写
sed "s/基本正则/替换内容/gi" x.txt
或
sed -e "s/基本正则/替换内容/gi" x.txt
或
sed -E "s/扩展正则/替换内容/gi" x.txt
基本正则和扩展正则
-
sed 用
-E
,-r
,--regexp-extended
启用扩展版正则 -
grep 用
-E
,--extended-regexp
启用扩展版正则
在基本正则表达式中,{n} 表示前面的字符连续出现n次,将会被匹配到。
在扩展正则表达式中,{n} 表示前面的字符连续出现n次,将会被匹配到。
在基本正则表达式中,( ) 表示分组,(ab) 表示将ab当做一个整体去处理。
在扩展正则表达式中,( ) 表示分组,(ab) 表示将ab当做一个整体去处理。
在扩展正则表达式中:
( ) 表示分组
(ab) 表示将ab当做一个整体去处理。
\1 表示引用整个表达式中第1个分组中的正则匹配到的结果。
\2 表示引用整个表达式中第2个分组中的正则匹配到的结果。
? 表示匹配其前面的字符0或1次
- 表示匹配其前面的字符至少1次,或者连续多次,连续次数上不封顶。
{n} 表示前面的字符连续出现n次,将会被匹配到。
{x,y} 表示之前的字符至少连续出现x次,最多连续出现y次,都能被匹配到,换句话说,只要之前的字符连续出现的次数在x与y之间,即可被匹配到。
{,n} 表示之前的字符连续出现至多n次,最少0次,都会陪匹配到。
{n,}表示之前的字符连续出现至少n次,才会被匹配到。
看了上述总结以后,是不是已经想要放弃使用"基本正则表达式"了呢?因为与之相比,扩展正则表达式才更符合我们这些懒人的习惯,而且,扩展正则表达式的可读性也更高,毕竟很多符号少了前面的"\",可读性就变强了。
扩展正则表达式中,还有一个常用的符号,是基本正则表达式中所没有的,它就是"|"
基本版正则
bash
grep -e 'hello\|nihao' x.txt
或
sed -e
扩展版正则
bash
grep -E 'hello|nihao' x.txt